محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ, صلاح الحجري أعبدالقادر البعداني 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المفردات الرئيسية ++€_(البرمجة 1) 
.١‏ المبادئ الأساسية والمتغيرات والجمل الشرطية والحلقات في ++]. 
. المصفوفات ۷ھ٣ا۸.‏ 
. الدوال وlلإۈجراءIت «Function and procedure‏ 
اسجlںڻٽ .Structures‏ 
المؤشرات sءام)«¡۴0.(برمجة‏ 2) 
. الملفات ءءآذ۴. (برمجة 2) 
. مقدمة Oriented Prog(OOP) je‏ ectز0bj.‏ (برمجة 3) 


المفردات التفصيلية ++€_(البر مجة مجه 1) 
مراجعة المبادئ الأساسية والمتغيرات والجتل الشرطية والحلقات في C++‏ . 
المتغيرات(أنواع - التصريح - الإسناد- شروط التعريف) 


چ م ن e‏ 


. الأدوات المستعملة (حسابية- الزيادة والنقصان- منطقية - علائقي ) 
ه أولية العمليات الحسابية . الثوابات الرمزية- التعليقات- أساليب الإدخال مزع الإخراج 
.cout‏ 


٠ه‏ جمل التحكم الشرطية 2 - (if - switch‏ الحلقات ) (for — do — while‏ 
۲. المصفوفات: 
٠‏ أنوع المصفوفات - تعريف - إعطاء قيم ابتدئيه - الوصول الي موقع محدد- 
طباعة محتويات المصفوفات - إدخال قيم من لوحة المفاتيح- 
عمليات على المصفوفات (جمع - طرح - معدل - اكبر....) - 
ترتيب المصفوفات - البحث فى المصفوفات -. 
۳. الدوال والإجراءات: 
فؤاد الدوال والإجراءات- أنوع الدوال والإجراءات - قواعد مجال الرؤية . 
.٤‏ السجلات: 
تعريف والتصريح عن السجلات- سجلات مصفوفات . 
ه. المؤشرات: برمجة 2 
المؤشرات كعناوين - المتغيرات المؤشرات -عمليات الموؤشر الحسابية- مؤشرات 
المصفوفات. 
. الملفات: برمجة 2 
دوال الإدخال- دوال الطباعة- دوال الإغلاق والفتح. 
Oriented Prog(OOP) jz naan .Y‏ ectز0bj.‏ برمجة 3 
تعريف والتصريح عن sووا‏ - تعريف مصفوفة ویوا . 
#include<iostream>‏ 
using namespace std;‏ 
void main ()‏ 


{ 
جسم البرنامج 
} 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


محاضرات مقرر البرمجة1 ٣++‏ 
( نظري + عملي) 


اعداد :أ. صلاح الحجري 
أ عبدالقادر البعداني 
salah_alhagrt @yahoo.com‏ : mail_ڑ_E‏ 
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محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المحاضرة الاولي برمجة 1:. 


ه المتغيرات(أنواع - - شروط تعريف المتغير-ات التصريح -الإسناد) 
تعريف المتغيرات : 
أنواع المتغيرات : 
شروط تعريف المتغيرات : 
التصريح (الإعلان): 
الإسناد ة 


ه الأدوات المستعملة (حسابية- الزيادة والنقصان- منطقية - علائقي ) 
حسابية: 
الزيادة والنقصان : 
منطقية : 
علائقي : 
أولية العمليات الحسابية : 
. الثوابات الرمزية-: 
التعليقات- : 
أساليب الإدخال رذع : 
أساليب الإخراج utه:.‏ 
٠‏ جمل التحكم الشرطية (? - (if - swi ch‏ 
lalaİlٽ‏ ) (for — do — while‏ 


if, if...else, switch, while, do...while or for 
e if statement (single selection) 
e if...else statement (double selection) 
e switch statement (multiple selection) 
e while statement 
e do...while statement 
for statement 
for (initialization; loopContinuationCondit 
ion; increment) 
statement 


WOOO OOCCOCCCCCOCCCOCCOCCCCOCCCOCCCCCCCCCCCCCCCCCCCCC 


for(int ] = x; j] <= 4 * x Ky; j] +=y / x ) 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


x=y=1 
for (int ] =x; ] <= 4 * x Ky; j] +=y / x ) 
cout<<j]<<" "; 


©e®®®®CCCCCCCCOCCCCCOCCOCCCOCCOCOCCCCCCCCCCCCOCCCOCCOCCCCCCOCCCOCCCCCCOCCCCCCCCCCCC 


©©O®®®GOCCGONCOGOCCOCCOCCOCCOCCOCOCOCCOCOCOCOCCOCCOCOCOCCGOCCGOCCCGOCGOCCOCCCGOCCCGOC 


a. Vary the control variable from 1 to 100 in increments 
of 1. 
b. for ( int ûi = 1; i <= 100; ãi++ ) 
c. Vary the control variable from 100 down to 1 in 
increments of -1 (that is, decrements of 1). 
for(int i = 100; i >= 1; i-- ) 
Vary the control variable from 7 to 77 in steps of 7. 
for(int ã = 7; i <= 77; i ك+‎ 7 ) 
. Vary the control variable from 20 down to 2 in steps of 
-2. 
h. for( int i = 20; i >= 2; 1 -= 2 ) 
i. Vary the control variable over the following sequence 
of values: 2, 5, 8, 11, 14, 17, 20. 
j. for ( int i = 2; i <= 20; 1 + 3 )( 
k. Vary the control variable over the following sequence of values: 
99, 88, 77, 66, 55, 44, 33, 22, 11, 0. 
l1l. for ( int i = 99; i >= 0; i -= 11 ) 


a Hm © 0 
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©we©c®c®®CCCCCOCCCCCOCCOCCCCOCCCOCCCCCCCCOCCCCCCOCCOCCOCCOCCCCOCCCCCCCOCCCCCCCCCCCOCC 


statement 
while ( condition ); 


©©O®®®O®O®CGCCCOCOCCOCCOCCOCCOCCOCOCOCCOCCOCCOCCOCCOCOCOCOCOCCOCCOCCOCCOCCCCCCCCOCO 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


{ 


statement 
} while ( condition ); 
initialization; 
while ( loopContinuationCondition ) 
{ 
statement 
increment; 
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if ( grade >= 60 ) 
cout << "Passed"; 
1f ( grade >= 60 ) 
cout << "Passed"; 
else 
cout << "Failed"; 


©©©®®®O®NCGCOCCOGOCCOCCOCCOCCOCCOCOCOCCOCCOCOCCOCCOCOCOCGOCCOCCOCCGOCCOCCCCCCCO 


cout<< (grade >= 60 ? "Passed" : "Failed" ); 
if ( studentGrade >= 90 ) 
// 90 and above gets "A" 
cout << "A"; 
else 
if ( studentGrade >= 80 ) 
// 80-89 gets "B" 
cout << "B"; 
else 
if ( studentGrade >= 70 ) 
// 710-79 gets "C" 
cout << "C"; 
else 
if ( studentGrade >= 60 ) 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


// 60-69 gets "D" 
cout << "D"; 
else 
// less than 60 gets "F" 
cout << "F"; 
if ( studentGrade >= 90 ) 
// 90 and above gets "A" 
cout << "A"; 
else if ( studentGrade >= 80 ) 
// 80-89 gets "B" 
cout << "B"; 
else if ( studentGrade >= 70 ) 
// 710-79 gets "C" 
cout << "C"; 
else if ( studentGrade >= 60 ) 
// 60-69 gets "D" 
cout << "D"; 
else 
// less than 60 gets "F" 
cout << "F"; 


©©O®®®GO®O®NCGOCCOCOCCOCCOCCOCCOCCOCOCOCCOCCOCOCCOCCOCOCOCOCCGOCCOCSCOCCOCOCCOCCOCOC 
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if ( y¥ > 5 ) 
cout << "x and y are > S5"; 


} 


else 
cout << "x is <= DB"; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 
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if ( studentGrade >= 60 ) 
cout << "Passed.\n"; 
else 
{ 
cout << "Failed.\n"; 
cout<<"You must take this course again.\n"; 


for ( count = 1; count <= 10; countt+ ) 
// loop 10 times 
{ 
if ( count == 5 ) 
break; 
// break loop only if x is 5 
cout << count << " "; 


// end for 
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for(int count = 1; count <= 10;count+t+ ) 
// loop 10 times 
{ 
if ( count == 5 ) 
// aif count is 5, 


continue; // skip remaining code in 
loop 
cout << count << " "; 
} 
// end for 
int d; 
cin>>d; 


switch (d) 
{ 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


case 1: 
cout<<"sen"<<endl; 
break; 

case 2: 
cout<<"MAD"<<endl; 
break; 
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// initialize row 
int column; 
// declare column 
while ( row >= 1 ) 
// loop until row < 1 
{ 
column = 1; 
// set column to 1 as iteration begins 
while ( column <= 10 ) 
// loop 10 times 


{ 
cout << ( IOW % 2 ? "<" : "p>" ); 
// output 
column++ ; 
// increment column 


// end inner while 
rOW--; 
// decrement row 
cout << endl; 
// begin new output line 


// end outer while ذıفiتdl‎ 
<<<<<<<<<< 
<<<<<<<<<< 
<<<<<<<<<< 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


<<<<<<< <<< 
<<<<<<<<<< 
<<<<<<< <<< 
<<<<<<<<<< 
<<<<<<< <<< 
<<<<<<<<<< 
<<<<<<<<<< 
int count = 1; 
// initialize count 


while ( count <= 10 ) 
// loop 10 times 


// output line of text 
cout<< (count%2?"x*x*x*x*":"++++++++") << endl; 
count+t+t; 
// increment count 


// end whi1e التنفيذ‎ 
E o o 


++++++++ 
9 ok ok o 


++++++++ 
o ok ok ok 


++++++++ 
o ok ok Kk 


++++++++ 
9 ok ok ok 


++++++++ 
for ( int i = 1; i <= 5; i++ ) 
{ 
for ( int j = 1; j] <= 3; ]++ ) 
{ 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


for ( int k = 1; k <= 4 ; k++ ) 
cout << '*'; 
cout << endl; 


// end inner for 
cout << endl; 


// end outer for التنفيذ‎ 


RR RF 
RF FF 
FF FF 


RR RF 
RR FF 
FF FF 


FF FF 
RR FF 
RF RF 


RR FF 
RR FF 
RR FF 


RR FF 
FF FF 
RR RF 
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r 


int x; 
// declare x 
int y; 
// declare y 
cout<<"Enter two integers in the range 1-20: 
cin >> x >> y; 
// read values for x and y 
for ( int ã = 1; i <= y; i++ ) 
// count from 1 to ¥ 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


{ 
for ( int ] = 1; ] <= x; j++ ) 
// count from 1 to x 
cout << '*'; 
// output @ 
cout << endl; 
// begin new line 
} 
التنفيذ‎ 
sefe fe ef 
sefe fe fe f 
sefe fe fe f 
sefe fe fe f 
sefe fe ef 


for ( int x = 19; x >= 1; x -= 2 ) 
cout << x << end1 ; التنفيذ‎ 


for (int x = 24; x >= 1; x-- ) 
cout << x << endl;  ڈيفغنتلا‎ 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


for (int x = 1; x <= 20; x++ ) 
{ 
cout << Xx; 
if ( x % 5 == 0 ) 
cout << endl; 
else 
cout << '\t'; 


} 

التنفيذ 

1 2 3 4 5 
6 7 8 9 10 
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cout << "Logical AND (&&)" 
<<"\nfalse && false: "<< ( false && false ) 
<<"\nfalse && true: "<< ( false && true ) 
<< "\ntrue && false: "<< ( true && false ) 
<< "\ntrue && true: " << ( true && true ) 
<< "\n\n"; 
التنفيذ‎ 
false && false: 0 
false && true: 0 
true && false: 0 
true && true: 1 
int x,y; 
cout<<"insert secon"; 
cin>>x; 
cout<<4*x*x+3*x-4<<endl; 
// برنامج لابجاد قيمة‎ 
4x +3x-4 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


اكتب برنامج يعمل علي تحويل ثواني مدخلة الي 
مايقابلها بالتثواني والدقائق والساعات 
int hour,mint, seco, temp, secon;‏ 
cout<<"insert secon";‏ 
cin>>secon;‏ 
seco=secon$ 60;‏ 
temp=secon/ 60;‏ 
mint=temp% 60 ;‏ 
hour=temp/ 60;‏ 
cout<<"hour="<<hour<<"mint="<<mint<<"seco="‏ 
<<seco<<endl;‏ 
int i, j] , n;‏ 
cout<<"insert the number";‏ 
cin>>n;‏ 
for( i = 1 ; i <= n ; i++)‏ 
{ 
for( ] = 1; ] <= 1 ; ] ++)‏ 
cout<<"*";‏ 


cout<<endl; 
} 
برنامج يقوم بطباعة (ه) الموضح في الصفحة//‎ 
الشكل‎ 
وضح الاخظاء في كل من الجمل البرمجية التالية:‎ 
1) 


For ( x = 100, x >= 1, x++ ) 
cout << x << endl; 

2( 

for ( x = 19; x >= 1; x += 2 ) 
cout << x << endl; 


3) 
if ( age >= 65 ); 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout<<"Age is greater than or equal to 
65" << endl; 
else 

cout << "Age is less than 65 << endl"; 


4) 
if ( age >= 65 ) 
cout<<"Age is greater than or equal to 
65" << endl; 
else; 
cout << "Age is less than 65 << endl"; 


5) 

while ( yy > 0 ) 

{ 
cout << ¥ << endl; 
ytt; 


©©© COCCCCCCOCCCOCCCOCCCCCCCCCOCOCCCCOCCOCCOCCCCOCCCOCCCCOCCCCCCCCCCCCCC 


int i = 1, j =2, k = 3 , m= 2; 

cout << ( i == 1 ) << endl; 

cout << ( ] == 3 ) << endl; 

cout << ( i >= 1 && j < 4 ) << endl; 

cout << ( m <= 99 && k < m ) << endl; 
cout << ( ] >= i || k == m ) << endl; 
cout<<( k + m < ] || 3 - ] >= k )<< endl; 
cout << ( !'m ) << endl; 

cout << ( !( ] - m ) ) << endl; 

cout << ( !( k > m ) ) << endl;1 


وضح نتائج كل سطر في البرنامج التالي 
int x=2,y=2,a=2,b=2,9=2,]=2,1=2;‏ 
cout<<(!( x < 5 ) && !( y >= 7 ))<< endl;‏ 
cout<<(!( a == b ) || !( g != 5 ))<< endl;‏ 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout<<(! (( x <= 8 ) &&€ ( y > 4 )) )<< endl; 


cout<<(! (( i > 4 ) || ( ] <= 6 )))<< endl; 
برامج متنوعة مطلوبه:‎ 
68- ( اكتب برنامج يعمل على تحويل وحدة القياس بايت الى مايقابلة‎ )١ 
سكعلاو؟)M‎ B-8 


۲) اكتب برنامج يعمل على أيجاد قيمة ۷من المعادلة 4 - ×3+×۷=5 

۳) اكتب برنامج لأيجاد مساحة ومحيط الدائرة ؟ 

؛) اکتب برنامج لأيجاد حاصل ضرب ومعدل تلاث قیم؟ 

) اكتب برنامج لآدخال مجموعة من الارقام وطباعتها بشرط يتوقف عند 
ادخال الرقم 5 ؟ 

)٦‏ اكتب برنامج لطباعة الكلمة ++) عشر مرات بدون استحدام الحلقات؟ 

۷) اكتب برنامج لأيجاد الرقم الاكبر بين رقمين؟ 

۸) اکتب برنامج لأيجاد قيمة 7 حيث 3×/¥۷+×7=5 بشرط ان ¥۷=<× ؟ 

)٩‏ اكتب برنامج لطباعة الارقام الفردية بين 55و 35 ؟ 

)٠١‏ اكتب برنامج لطباعة الارقام الزوجية بين 100و 2 ؟ 

)١‏ اكتب برنامج لأيجاد مجموع الارقام الزوجية بين 100و 2 ؟ 

۲) اكتب برنامج لأيجاد مجموع الاعداد من 1 الى ر؟ 

۳) اكتب برنامج لأيجاد العدد الاصغر بين ثلاثة اعداد ؟ 

؛) اكتب برنامج لقراءة عدد ثم اوجد الرقم الاكبر في العدد المدخل ؟مثال 
3 اللرقم الاکبر هو 7 ؟ 

)٠‏ اكتب برنامج لتحويل رقم عشري الى ثنائي ؟ 

)١‏ اكتب برنامج لقراءة عدد 1 الى 7 ثم طباعة اسم اليوم؟ مثال عند ادخال 
العدد 2يطبع الاحد؟ نفس البرنامج خاص بالاشهر؟مستخدماً جمل عسي ؟ 


۷) اكتب برنامج لمعرفة عدد الاعداد الزوجية من والفردية ......... لم يكتمل 
۸( اكتب برامج لطباعة الاشكال التالية :كل شكل برنامج مستقل؟ 


(bj) (2) 
Hk ok kkk koko r ohr oir ro o o o ok 
KkkHRHHK KK HHHRRRHHkK 
HHH HRRK Kk HHRRHRHH#K 
HHkKRR# KHHHRHR# 
KH KR # HHKRHR# 


kkk RHk# kk HF FF HHHH Hkh kk 
HHHH HH Fk Hkh Hk 
kHirkkkhihk Hk kkk HHkkkk kk 
hkHkkHkkKkKk# Hk kk kHkHkHkkHHRkH 
HkHkkHHHHkkHH # H# HEHEHE 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 
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7 ۰ 
السابقهء‎ 
o0 ¬ 


i1f,if...else, switch, while, do...while or for 


e if statement (single selection) 

e if...else statement (double selection) 
e switch statement (multiple selection) 

e whi le statement 

e do...whi le statement 

e for statement 


ملاحظة. تلبيه:. 
لاحظ المقطع التالي بمعظم البرامج لم تكتب وذلك للاختصار ولكن أنت عند 
التطبيق والمذاكرة والاختبار يجب عليك كتابة المقطع كامل علماً ان المقطع يتبع 
بيئة الدوت نت ويمكنك تنفيذ البرامج في بيئة ال Borland‏ ولكن تحتاج الى 
إضافة بعض المكاتب حسب البرنامج . 
#include<iostream>‏ 
using namespace std;‏ 


void main () 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المحاضرة : مجموعة من البرامج توضح عمل الحلقات 
والجمل الشرطية.. 


)١‏ اكتب برنامج لطباعة الشكل:. 


#include<iostream> 
using namespace std; 
void main () 
{ 
int ãi,j],n; 
cout<<"insert n"; 
cin>>n; 
for (i=1;1i<=n;i++) 
{ 


for (j]j=1;]<=i;]++) 
cout<<]<<" "; 
cout<<endl; 
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int ãi,j],n; 
cout<<"insert n"; 
cin>>n; 
for (i=1;1i<=n;i++) 
{ 
for (j]j=1;]>=1;j]--) 
cout<<j]<<" "; 
cout<<endl ; 
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محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


)٣‏ اكتب برنامج لطباعة الشكل:. 


int i,j],n; 
cout<<"insert n"; 

cin>>n; 

for (i=n;1i>=1;1--) 

{ 
for (j]=1;]<=n; j++) 

cout<<]<<" "; 

cout<<endl ; 


©©©®®®GO®NGCONCGOCOCCOCCOCCOCCOCCOCOCOCCOCCOCOCCOCCOCOCCOCOCCOCCOCSGOCOCCOCCOCCOCOC 


؛٤)‏ اكتب برنامج لطباعة الشكل:. 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


©©®®®®CCcCCCCOCCCCCCCCCCCOCCCCCCCCCOCCCOCOCCCCOCCCCOCCOCCCCCCOCOCCCOCCCOCCCOCCCCCCCCCCC 


int ãi,j],n; 
cout<<"insert n"; 
cin>>n; 
for (i=n;1i>=1;1--) 


{ 


for (j=i;]<=n; j++) 
cout<<]<<" "; 
cout<<endl ; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


علماً ان قيمة 


كوز يتبع المحاضرة السابقة // 


ماهو ناتج تنفيذ البرنامج التالي(1 


#include<iostream> 
using namespace std; 


void main () 


{ 


int s,d,a,b,m,c,x;// 5= s 


المتغدر 
cin>>s;‏ 
x=s;‏ 


for (d=1;d<=s;d++) 


{ 


for (m=x;m>=1;m--) 


{ 
cout<<" "; 
} 
xXx-=17; 
if (d>=2( 
{ 


for (c=d;c>=2;c--) 


{ 
COUÈE<<C; 
} 
} 


for (a=1;a<=d;a++) 


{ 


cout<<a; 

} 
cout<<"\n"; 
} 

} 


اكتب التنفيذ على هذه الصفحة 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


كوز يتبع المحاضرة السابقة // 
ماهو ناتج تنفيذ البرنامج التالي(2 


#include<iostream> 
using namespace std; 
void main () 
{ 
int ã , j] , n; 
cout<<"insert the number:" ; 
cin>>n; //5= علماً ان قيمة المتغيره‎ 
for( i=1 ; i <= n ;i++) 
{ 
for( ] =1 ; ] <= n-i ; ]++) 
cout<<" "; 
for( ]=1 ; ] <= 1 ;3++) 
cout<<"*"; 
for( ] =1 ; ] <= 1-1 ;]++) 
cout<<"*"; 
cout<<"\n"; 
} 


} 
اكتب التنفيذ على هذه الصفحة 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


/ كوز يتبع المحاضرة السابقة/‎ 
ماهو ناتج تنفيذ البرنامج التالي(3‎ 
#include<iostream> 
using namespace std; 
void main () 
{ 
int 31 , J ; n; 
cout<<"insert the number:" ; 
cin>>n; //5= ١۸ علماً‎ 
ان قيمة المتغير‎ 
for( i= n; i >=1 ;1i-¬-) 
{ 
for( ] =1 ; ] <= n-i ; J++) 
cout<<" "; 
for( ]=1 ; ] <= 1 ;3++) 
cout<<"*"; 
for( ] =1 ; ] <= 1-1 ;]++) 
cout<<"*"; 
cout<<"\n"; 
} 


} 
اكتب التنفيذ على هذه الصفحة 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


العنوان المحاضرة : Arrays‏ المصفوفات 
سندرس في هذه المحاضرة المفردات التالية والتوضيح (الشرح في المحاضرة ) 
)١‏ تعريف المصفوفات» الاعلان عن المصفوفات. 
) انواع المصفوفات. 
)٣‏ إعطاء قيم ابتدائية. 
)٤‏ الوصول الى موقع محدد في المصفوفة عمود او صف 
ه) طباعة محتويات المصفوفة. 
)١‏ ادخال قيم من لوحة المفاتيح الى المصفوفة. 
۷) عمليات على المصفوفات مثلاً بعض العمليات ( جمع مصفوفتين - ضرب - 
طرح- حساب معدل اکبر قيمة- .. .الخ من العمليات). 
۸( ترتیب المصفوفات تصاعدياً ءتنازلياً . 
)٩‏ البحث في المصفوفات. 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المصفوفة ۸٣٣4۵3١‏ :. هي مجموعة مرتبة من البيانات التى تحتوى 
على عدد ثابت من العناصر او غير ثابت . 
او مجو عة من البيانات التي تتشابها في النوع double , int , char , float‏ 


هناك ثلاث أشياء يجب أن تاخذ بعين الاعثبر عند النصريح عن المصفوفة 
4 سم المصفوفة : وهو اسم لخئاره مللما نخثار اسم أ ي ملعپر. 


# عددالعناص الئ, ذاخلها 
دد لارا الل بد کدی 
5 وع ایبانات ال نخدم فیها. 


1n ‌c]12[; بعد واحد//‎ 

int b[]100][, x]27[; ][; بعد واحد//‎ 
int array1[ 2 ][ 3 ]; //jيدعب‎ 

int b] 2 [] 2 بعدين//;[‎ 


انواع المصفوفات :. 

1) مصفوفات احادية البعد 2) مصفوفات متعددة الابعاد(ثنائئة - ثلاثية -...). 
ملاحظة : ليس ارقام فقط يمكن ان نقوم بعمل مصفوفة من اسماء طلاب او غير 
ذلك.. 
شكل بعض من المصفوفات رياضياً 

e [4 34 56 10 77 51 93 30 5 52[ 


أارقام ذات صف واحد وعدد من الاعمدة 


77 

ارقام ذات عمود واحد وعدد من الصفوف 

بعدين مكونة من عمودين وصفين 93 51 ° 
5 30 

بعدين مكونة من ثلاثة صفوف وتلاثة اعمدة 77 10 56 e‏ 
30 93 51 
10 52 5 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


إعطاء فيم ابتدائية. 


= int x[ 5|]={44,55,66,88,90}; 

= int array1[ 2 ][ 3] = { { 11, 22, 3 }, {1 4, 55, 6 } }; بعدين//‎ 
= x[l]=55; 

= x[4]=90; 


array1[ 0 ][ 0 [ = 11;// بعدين‎ 


الوصول الى موقع محدد في المصفوده عمود او صف 
cout<<x[1]<<endl<<x[4];‏ 
x[1]= 55;‏ 
x[4]= x[1];‏ 


طباعة محتويات المصفوفة. 
cout<<x[1]<<endl<<x[4];‏ = 
for(int i=0;1<5;1++)‏ = 
cout<<x[1]<<endl;‏ 
cout<<endl;‏ 


ادخال قيم من لوحة المفاتيح الى المصفوفة. 


int a[5]; 

forint k=0;k<5;k++) 

{ 

cout<<"insert elements array"<<endl; 
cin>>a[k]; 

cout<<endl; 


} 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


برامج: لمصفوفة البعد الواحد . 
0 ارا ره اة ا لتر ا عفرو تة مرن العا ۲ 
الى مصفوفة أخرى ثم طباعة محتويات المصفوفتين؟ 


int x[4], y[4]; 

for (int i=0;i<4;1i++) 

{ 

x[1]=i; 

yl[i]=i*i; 

cout<<endl<<x[i1]<<" "<<y[i1]; 
} 

cout<<endl; 


2) هذا البرنامج يقوم بإعطاء قيم ابتدائية لمصفوفة ثم يقوم بطباعتها ؟ 
وظيفة: اكتب نفس البرنامج ولكن يقوم بطباعة القيم الابتدائية بشكل عكس أي 
يطبع 80 تم 70 ...الخ 


int a[5]={100,70,50,70,80}; 
for(int i=0;i<5;1i++) 
cout<<a [i1] <<endl; 
r 


6 هذا البرنامج يقوم بحساب وطباعة متوسط المرتبات واجمالي المرتبات لد 5 
خمسة موظفين حيث أعطيت المرتبات قيم ابتدائية . 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


int array1[5]={100,50,50,100,50}; 
int s=0; 

for(int a=0;a<5;a++) 

s=s+array1l [a]; 

float avg=s/5; 
cout<<avg<<endl<<s<<endl ; 


4 هذا البرنامج يطلب من المستخدم إدخال مرتبات 10 عشرة موظفين ثم يقوم 
بحساب اجمالي وطباعة متوسط هذه الرواتب . 


float salary [10]; 

float average; 

average = 0.0; 

for( int count=0; count<10 ; count++) 
{ 

cout<<"please enter salary f employee 
"<<count+1 <<" و‎ 

cin>>salary [count] ; 

average += salary [count] ; 


} 


cout<<"average salary"<<average/10<<endl; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المحاضرة السابقة:. 

1)تعريف المصفوفات» الاعلان عن المصفوفات. 

int c[12]; 
2)انواع المصفوفات.المطلوب بعد واحد وثنائي البعد.‎ 
إعطاء قيم ابتدائية.‎ 

int x[ 5]={44,55,66,88,90}; 

4 ) الوصول الى موقع محدد في المصفوفة عمود او صف. 

x[4]= 90; 


5) طباعة محتويات المصفوفة. 
forint i=0;1<5;1++)‏ 
cout<<a[1]<<endl;‏ 
) ادخال قيم من لوحة المفاتيح الى المصفوفة. 


for( int count=0; count<10 ; count++) 
cin>>salary [count]; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


العنوان المحاضرة: ترتيب - وبعض العمليات -بحث. 

1) ترتيب المصفوفات تصاعدياً ءتنازلياً . 

2) عمليات على المصفوفات مثلا بعض العمليات ( جمع مصفوفتين - ضرب - 

طرح-اكبر قيمة- ...الخ من العمليات). 

3 البحث في المصفوفات. 

ترتيب المصفوفة: 

هناك طرق عديدة لترتيب المصفوفات» سنكتفي هنا بشرح إحداهاء وهي طريقة 
الفقاعة S0۲٤‏ م1طط0 8 وسنحيل الطريقة الأخرى الأفضل والأسرع -( وهي طريقة 
الترتيب السريع S0۲۲‏ )عزں - غير مطلوبة برمجيا فهم عملها فقط وكذلك الطرق 
الاخرى). 

- ما هو ترتيب الفقاقيع هذا؟.. وهل لهذا علاقة بالصابون والمنظّفات؟ 

- يبدو أك على حق!.. فهذه الطريقة في الترتيب تستخدم نظريّة: الأخفٌ يطفو! 

- كمن فسّر الماءَ بعد العُسر بالماء!.. هل يبدو لك أنك أضفت لي جديدا؟ 

ء الحكاية وما فها أننا ستقارن قمة كل خانة فى الضفو فة بما يليه فاذا كانت 
الخانة التالية أصغرء يتم تبادل قيمتها مع الخانة الحاليّة.. إِنَّ هذا في النهاية 
سيجعل العناصر الأصغر تطفو إلى بداية المصفوفة.. تماما كما تفعل الفقاقيع 
حينما تتصاعد إلى سطح الماء. 

- أعتقد أثني فهمت» ولكذني ما زلت في حاجة لبعض الإيضاح. 

- إذن فلنأخذ مثالا عمليًا. 

افترض أن لدينا المصفوفة التالية. 


E QIN A 


3 
سا مقار ا اور ما یا کف ان ها ارق 5وو اکر ن ار 
2.. ٳذن فلا بڏ من مبادلتهما: 


0 کک این 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


e O E 2 ا‎ 
.3 والرقم‎ 

ننتقل الآن للخانة الثانية.. سنجد أن الرقم 5 أقكَ من الرقم 6» ولكنه أكبر من الرقم 4.. 
إذن فلا بد من "تعويم" الرقم 4 إلى أعلى: 


ا ا ف ا 


وكما اعتدنا سنواصل باقي عمليّة المقارنةء ولكن بالأخذ في الاعتبار أنٌ الخانة الثانية 
صارت تحتوي على الرقم 4. . هنا سنجد أنه أكبر من الرقم 3 مما يعني حتمية 
مباداتهما: 


دا ندا | |۸ 


4 
الآن نصل للخانة الثالثةء وفيها الرقم 6.. للأسف سنجده أكبر من الرقم 5 (لاحظ أن 
هذه هي المرَّة الثانية التي نقارن فيها هذين الرقمين.. إِنَّ هذا من عيوب هذه الطريقةء 
حيث يكون عدد المقارنات كبيرا).. الآن سنبادلهما: 

ر 
3 
5 
6 
4 
وسنواصل المقارنة على الخانة الثالثة وفيها الرقم 5.. سنجد أنه أقلّ من الرقم 4.. فلنشم 
بعمل اللازم: 


OE WN 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


نصل الآن لمقارنة الخانة الرابعة بما يليها.. سنجد فيها الرقم 6.. آه.. هذه هي المرّة 
الثالثة التي نقارنه فيها بالرقم 5!!.. اليس شيئا مملا؟ 
طبعا يجب تعويم الرقم 5. 


دا ادن خط ا0nا VQ‏ 


نصل الآن للخانة الأخيرة.. لم يعد هناك ما نقارنها به.. إذن فقد انتهت العمليّة.. وطبعا 
المصفوفة الآن مرتبة!. . لاحظ أتنا نستطيع الاستغناء عن مقارنة الخانة الأخيرة مع 
بعدهاء لأنها بالفعل بلا فائدةء فلا توجد آي خانات بعدها!! 
وقبل أن تطلق أي اعتراض على هذه الطريقة وما بها من عيوب» يجب أن أحيطك 
علمًا بأن كتابة الكود لهذه الطريقة يعد أسهل ما يمكن» وهي الميزة الوحيدة في 
الموضوع!! ۰ 
تعالو نر هذا البرنامج: 

ا( اكتب برنامج لقراءة مصفوفة أحادية مكونة من 5 عنصر ثم راتب عناصرها 

تصاعدياً ثم أطبعها مرتبة ؟ وظيفة تنازلياً؟ 


int x[5]; 
int temp; 
for( int count=0; count<5 ; count+t+) 


{ 

cout<<"please enter x f elmen:"<<count+t1 

<<" 

قراءة المصفوفة اى إدخال عناصر ; cin>>x [count]‏ 
المصفوفة } 


for( int i=0; i<5 ; i++) 
// ' جملة تكرارية لكل خانة من خانات المصفوفة‎ 
for( int J=i+l; j<5; J++) 
// ' جملة تكراربّة لكل الخانات التالية للخانة الحاليّة‎ 
if (x[i]>x[j]) 
{ 
temp=x [i]; // التبديل‎ 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


x[i]=x[j]7; 
x[j]=temp; 
} 
for( int i=0; i<5 ; i++) 
// طباعة عناصر المصفوفة‎ 
cout<<x [1] <<endl; 


عمليات على المصفوفات ذات بعد واحد: 
)٣‏ اكتب برنامج لقراءة مصفوفة أحادية مكونة من 20 عنصر ثم أطبعها 
بشکل معکوس 
int x[20];‏ 
for( int count=0; count<20 ; count++)‏ 
{ 
cout<<"please enter x f elmen‏ 
"<<count+1 <<" N‏ 
cin>>x [count] ;‏ 
} 
for( int i=20; i>=0 ; 1i--)‏ 
cout<<x [i1] <<endl;‏ 
3 اكتب برنامج لقراءة مصفوفتين أحادية مكونة كل منهما 15 عنصر ثم ادمج 
المصفوفتين بمصفوفة واحدة حجمها 30 ؟ 
int a[15],b[15],c[30];‏ 
for( int x=0; x<15 ; x++)‏ 
{ 
cout<<"please enter a f elmen : "<<x+t1‏ 
2 "<< 
cin>>a [x] ;‏ 
cout<<"please enter b f elmen : "<<x+t1‏ 
"<< 
cin>>b [x];‏ 
} 
for( int i=0; i<30 ; i++)‏ 
{ 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


if (1<15( 
c[i]=a[i]; 
else 
c[i]=b[i-15]; 
} 
for( int ]J=0; j]<30 ; ]++) 
cout<<c[]J]<<" "; 
4)اكتب برنامج لقراءة مصفوفة أحادية مكونة من 15 عنصر ثم اوجد العنصر‎ 
الأكبر من بين عناصر المصفوفة ثم أطبعها العنصر ؟ وظيفة الأصغر ؟‎ 
int myarray [15]; 
int max; 
for( int x=0; x<15 ; x++) 
{ 
cout<<"please enter y elmen: "<<x+t1<<" "; 
cin>>myarray [x]; 
} 
max=myarray [0] ; 
for( int i=0; i<15 ; i++) 
//{ 
1f (myarray [i] >max) 
max=myarray [i] ; 
/1۲ 
cout<<max<<" "; 
اكتب برنامج إدخال مصفوفة أحادية ثم يوجد مجموع الإعداد الزوجية‎ 5 
ومجموع الإعداد الفردية:‎ 


int a[40]; 

int n,i,s1l,s2; 
cout<<"\ninsert n:"; 
cin>>n; 

for (i=0;i<n;i++) 

{ 
cout<<"a[]"<<i<<"]="; 
cin>>a [i]; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


} 

s1=s2=0; 

for( i=0; i< n; i++) 

if (a[i] 52==0) 

s1+=a[i]; 

else 

s2+=a [i]; 

cout<<"\nsum even element:"<<s1; 
cout<<"\nsum odd element:"<<s2<<"\n"; 
اكتب برنامج إدخال مصفوفة أحاديه ثم فصلها إلى مصفوفتين من الإعداد‎ )6 

الزوجية والفردية: وظيفة 
7]) اكتب برنامج إدخال مصفوفة أحاديه ثم يطبع الأعداد التي تقبل القسمة على 


العدد ثلاثة؟ وظيفة 
8 اكتب برنامج إدخال مصفوفة أحاديه ثم ابحث عن عنصر مدخل في المصفوفة 
؟ وظيفة 


9) اكتب برنامج إدخال سلسله نصيه ثم يعيد طول السلسلة 
char s[256];‏ 
int i,k;‏ 
cout<<"\nINSERT STRING:\n";‏ 
gets (s);‏ 
k=0;‏ 
for (i=0;s[i]!='\0';i++)‏ 
k++;‏ 
cout<<"\nlength s:"<<k<<endl;‏ 
0) اكتب برنامج إدخال سلسله نصيه ثم يحسب عدد الفراغات: وظيفة؟ 
1) اكتب برنامج إدخال سلسله نصيه ثم يحول الأحرف الكبيرة إلى صغيره 
والعكس: هذا الموضوع له علاقة بجدول أسكي ؟ وظيفة؟ 
2) اکتب برنامج يقوم بطرح بين مصفوفتين: وظيفة؟ 
3) اكتب برنامج لقراءة مصفوفتين أحادية مكونة كل منهما 15 عنصر ثم 
أطبع حاصل ضرب المصفوفتين؟ وظيفة 
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محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


4) اكتب برنامج يقوم بجمع بين مصفوفتين (أي جمع عناصر المصفوفة ۾ 
مع عتاصر المصفوفة ط وطباعة ناتج الجمع في مصفوفة ع ؟ 

int a[5]={10,20,10,30,40}; 

int b[5]={40,30,40,20,10}; 

int c[5]; 

for(int i=0; i<5; i++) 

c[i]=a[i]+b[i]; 

cout<<"\nTHE ARRAY XIt+Y =\n"; 
COUE<<K"\n=====——=——uuuuuu——— \n"; 
for(int j]=0; j<5;]++) 

cout<<c[]J]<<" "; 
COUE<<"\n-====—=———uuu———— \n" ; 


البحث في المصفوفات: 
يوجد عدة طرق احدي الطرق الطريقة التقليدية كمايلي. 
5)کتب برنامج للبحث عن عنصر مدخل في مصفوفة أي هل العنصر موجود او 
غير موجود ؟ 
int‏ 
a[10]={10,30,22,12,40,66,80,90,23,100};‏ 
int k,i;‏ 
cout<<"insert k";‏ 
cin>>k;‏ 
int b=0;‏ 
for( i=0; (i<10) && (b==0) ; i++)‏ 
{ 
cout<<i<<" ";‏ 
if (a[i]==k) b++t;‏ 


} 

if (b==0) 

cout<<" not found "; 
else 

cout<<" found و‎ 


cout<<"index '"<<i<<endl; 
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محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


)١‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم أطباعتها ؟ 

) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة 
الإعداد الزوجية ؟ 

۳) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة الإعداد 
الفردية ؟ 

؛) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعتها 
معكوسة (تبدأً الطباعة من العنصر الأخير) ؟ 

ه) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة 
مجموع عناصرها ؟ 

) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١N‏ عنصر ثم طباعة عدد 
الأعداد الفردية فيها ؟ 

۷) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١N‏ عنصر ثم طباعة عدد 
الأعداد الأولية فيها ؟ 

۸) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة الأعداد 
التي تقع في المواقع الزوجية ؟ 

)٩‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة اكبر 
عنصر فيها ؟ 

)٠١‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة اكبر 
عنصر واصغر عنصر فيها ؟ 

)١‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة 
موقع اكبر عنصر فيها ؟ 

)۲١‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة 
مجموع المواقع التي تحتوي على أعداد أولية 

۳) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة 
الأعداد التي تقبل القسمة على العدد 5 ؟ 

)٤‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعة 
الأعداد الفردية التي أكبر من العدد 10 ؟ 

°) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم طباعتها 
مرتبة ترتيب تصاعدي ؟ 

)١‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١N‏ عنصر ثم طباعة أكبر 
عددین فیها ؟ 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


۷) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة 
أسماء طلاب ) ثم طباعة الأسماء مرتبة أبجديا ؟ 

۸) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة من 
أسماء طلاب ) ثم طباعة عدد الطلاب الذي اسمهم إ۸ ؟ 

۹) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١N‏ عنصر(مصفوفة 
رموز) ثم طباعة الرموز التي بشفرة أسكي لكل رمز فيها ؟ 

)٠١‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة 
حروف) ثم طباعة الرموز التي بشفرة أسكي لها أعداد زوجية ؟ 

١‏ ) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة 
رموز) ثم طباعة الرموز التي مواقعها في المصفوفة تقبل القسمة على 3 
¢ 


)۲١‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة من 

( برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة من 
أسماء طلاب) ثم طباعة صاحب أطول اسم منهم ؟ 8 

؛) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة من 
أسماء طلاب) ثم طباعة مجموع شفرة الاسكي لرموز كل اسم منهم ؟ 

٠‏ ) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة أرقام 
) ثم طباعة الأعداد الفردية في أول المصفوفة والأعداد الزوجية في نهاية 
المصفوفة ؟ 

)٠١‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة 
سلاسل نصية ) ثم طباعة كل سلسلة نصية لا تحتوي على فراغ ؟ 

۷) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر(مصفوفة 
أسماء طلاب ) ثم طباعة عدد الطلاب تحتوي أسماءهم على الحرف و ؟ 

۸) برنامج يقوم بقراءة مصفوفتين أحادية مكونة كل منهم ١‏ عنصر ثم 
طباعة العناصر المشتركة بين المصفوفتين ؟ 

۹) برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١N‏ عنصر ثم يقوم 
بالمبادلة بين العنصر الذي موقعة 1× والعنصر الذي موقعة 2× ؟ 

)٠‏ برنامج يقوم بقراءة مصفوفة أحادية مكونة من ١‏ عنصر ثم يقوم 
بالمبادلة بين العنصر الأول في المصفوفة مع العنصر الأخير . 
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محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


ماتم عملة على المصفوفة ذات البعد الواحد يتم على 
i el‏ بعدين : 
.١ 1‏ عمليات على المصفوفات مثلاً بعض العمليات ( جمع مصفوفتين ضرب _ 


طرح -اكبر قيمة- .. .الخ من العمليات). 
۲. ترتیب المصفوفات تصاعدياً ءتنازلياً . 


۳. البحث في المصفوفات. 
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محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المحاضرة المصفوفات ذات بعدين:. 
1 تعريف المصفوفات» الاعلان عن المصفوفات. 
=int b[ 2 ][ 2 ];‏ 
=int array2[ 2 ][ 3 J];‏ 
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2)الشکل الریاضی 
بعدين 77 10 56 
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3)إعطاء قيم ابتدائية. 
int array1[2] [3]={{1,2,3},{ 4, 5, 6} };‏ 
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4)الوصول الى موقع محدد في المصفوفة عمود او صف. 
"al 0 ][ 0 ] =0;‏ 
"al 0 ][ 1 ] =0;‏ 
"al 2 ][ 1 ] = a[ 2 ][ 3 ] =0;‏ 
5)طباعة محتويات المصفوفة. 
طريقة 1 
for ( int i = 0; i < 2; i++ )‏ 
{ 


for ( int j = 0; j < 3; j++ ) 
cout << a[ i ][ j] ] << ' '; 
cout << endl; 


} 
طريقة -هذه الطريقة تكون الطباعة بشكل مصفوفة ثنائية كم في كتاب الرياضيات // 
طريقة 2 


const int arraySize = 3; 

// يمكن استخدام ثابت لابعاد المصفوفة‎ 
int table[arraySize ] [arraySize]; 
cout << " [0] [1] [2]'" << endl; 
for ( int i = 0; i < arraySize; i++ ) 


{ 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout << '[' << i << "] "; 
for ( int ]J = 0; j] < arraySize; j++ ) 
cout <<'\t' << table[ i ][ j] ] << " "; 
cout << endl; 


6 ادخال قيم من لوحة المفاتيح الى المصفوفة. 
const int arraySize = 3;‏ 
int table[arraySize ] [arraySize];‏ 
for ( int i = 0; i < arraySize; i++ )‏ 
{ 
for ( int j] = 0; j < arraySize; j]++ )‏ 
{ 
cout << "[" << i << "][ "<< j<< "]:‏ 


cin>>table[ i ][ j ] ; 
cout << endl; 
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محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


برامج : 


مثال1: فی أحدى الفصول الدراسية كانت نتائج ثلاثة طلاب كما هو موضح 


بالجدول التالي: 


الطالب الاول 
الطالب الثانى 
الطالب الثالث 
المطلوب: 


٣++ لغة‎ 
7T 
60 
89 


VB.NET 
80 
70 
90 


هیاکل بیانات 
78 
87 
88 


كتابة برنامج لأدخال درجات ثلاثة طلاب للثلاث المواد الدراسية ثم قم بطباعة 


الدرجات؟ 


ماهو المطلوب لعمل ذلك؟ اولاً تعريف مصفوفة ذات بعدين مكونة من ثلاثة 
صفوف وثلاثة اعمدة. وبعد ذلك يطلب من المستخدم ادخال البيانات الموضحة 
في الجدول ويتم بذلك تخزين الدرجات في المصفوفة ثم بعد ذلك طباعة الدرجات 
المدخلة .ملاحظة :. تمرين: مطور بعد السؤال رقم 18 صفحة رقم ؟ 

const int arraySize = 3; 
int table[arraySize ] [arraySize]; 


++ ( 


jJ < arraySize; j++ ) 


for ( int i = 0; i < arraySize; 


{ 


for ( int j] = 0; 


{ 


cout << "[" << i << "][ "<< j<< "]: "; 


[deg3]" << endl; 
1++ ) 


cin>>table[ i ][ j ] 
cout << endl; 


[deg1] [deg2] 
for ( int i = 0; i < arraySize; 


} 
} 


cout << " 


{ 


cout << " [student " << itl << "]: "; 
j < arraySize; j++ ) 
cout<<'\t'<<table[ i ][ j ] << " "; 


for ( int j] = 0; 


cout << endl; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


2) أعطاء قيم ابتدائية لمصفوفة ذات بعدين عبارة عن خمسة صفوف في 
خمسة اعمدة ثم عكس اقطار المصفوفة ؟ 
مالمقصود باقطار المصفوفة // a,65,1,[;‏ خ٣‏ 
a=4;‏ 
int‏ 
x[5] [5]={1,2,3,4,5,6,7,8,9,10,11,12,13,14‏ 
;}25 ,15,16,17,18,19,20,21,22,23,24, 
for (i=0;1i<5;1i++)‏ 
{ 
for(j=0;]<5;]++)‏ 
{ 
([==) 1£ 
{ 
b=x[i11][]];‏ 
x[i] [j]=x[i] [a];‏ 
x[i] [a]=b;‏ 


} 

} 

a-=1; 

} 

for (i=0;i<5;1i++) 
{ 

for (]j=0;]<5;]++) 
{ 

cout<<x[i1] [jJ]<<" "; 
} 

cout<<"\n"; 

} 
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محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


.. أمثلة متعددة‎ 
1)اكتب برنامج لقراءة مصفوفة ثنائية مكونة من م عنصر ثم اوجد العنصر‎ 
الأكبر من بين عناصر المصفوفة ثم أطبعها العنصر ؟‎ 
{ 
int maxa [100] [100]; 
int ãi,j]J,m,n; 
cout<<"insert n:\n"; 
cin>>n; 
COUE<<"\n--=---—-———=——=—=—=—=—=—==—=-- \n"; 
cout<<"insert array:\n"; 
for (i=0; i<n;i++) 
for (]J=0; j<n;j]++) 
cin>>maxa [i] [J]; 
COUE<<"\n--=-=-—-—-——=——=—=—=—========--- \n"; 
m=maxa [0] [0] ; 
for (i=0; i<n;i++) 
for (]J=0; j<n;j]++) 
if (maxa[i] [jJ] >m) 
m=maxa [i] [j]; 
cout<<"max:='"<<m<<endl ; 


2)اكتب برنامج لقراءة مصفوفة ثنائية مكونة من م عنصر ثم قم بترتيب عناصر 
المصفوفة ترتيب تصاعدي ؟ 


{ 
int sort_up [100] [100]; 
int n; 
int i1;il;JL;J?; 
cout<<"insert n:\n"; 
cin>>n; 
COUt<<"\N======—=—=———————————— \n"; 
cout<<"insert array:\n"; 
for (i=0; i<n;i++) 
for (]J=0; j<n;j]J++) 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cin>>sort_up[i] [j]; 

COUE<SS" (A= \n"; 
for (i=0; i<n;i++) 

for(]j=0; j<n;j++) 

for (i1=0; i1<n;i1++) 

for (]1=0; j1<n;j1++) 

if (sort_up[i] [j]<sort_up[i1] [j11) 


{ 
int +t; 
t=sort_up[i] [jJ]; 
sort_up[i] [J]=sort_up[i1] [j1]; 
sort_up[i1] [J1]=t; 
} 
COUE<<"\n-====—=—=————uuuu————— \n"; 


for (i=0; i<n;i++) 
for(]j=0; j<n;j++) 
cout<<sort_up[i] [j]; 


3 جمع مصفوفتين ذات بعدين 
for (i=0; i<n; i++)‏ 
for(j=0; j<n; j++)‏ 
cl[i]l[j]=al[i]l[j]+tb[il]l[]] 7;‏ 


إذا كان المطلوب ضرب مصفوفين ذات بعدين ؟ ما هو شرط الضرب وكيف نقوم 
بعمل برنامج لذلك ؟ 


clil[j]=c[lil[j]+ ali] [s]*b[s][j]; 
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محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


4)اكتب برنامج لقراءة مصفوفة ثنائية مكونة من م عنصر ثم قم بتصفير جميع 
عناصرها ثم قم بطباعتها ؟ 

int ziro2up [100] [100]; 

int i,j]j,m,n; 

cout<<"insert n:\n"; 

cin>>n; 

COUt<<"\n=====—==—=—=—=—=—==-- \n"; 

cout<<"insert array:\n"; 

for ( i = 0; i < n; i++ ) 

{ 


for ( j] = 0; j < n; J++ ) 

{ 

cout << "[" << i << "][ "<< j<< "]: "; 
cin>>ziro2Zup[ i ][ j ] ; 
cout << endl; 


} 


coUut<<"\n-====-=—=—=—=—= \n"; 
for (i=0;i<n;i++) 
for (j]j=0;]<n;jJ++) 
if (i+j<=n+1) 
ziro2up [i] [j]=0; 
COUI<<" \n= === \n" 
for ( int i = 0; ãi < n; i++ ) 
{ 
cout << "[ " << i+1 << "]: "; 
for ( int ] = 0; j < n; ]I++ ) 
cout<<'\t'<<ziro2up[i] []]<< " "; 
cout << endl; 


©©O®®®G®O®NCGCOCCGOCOCGCOCCOCCOCCOCCOCOCOCCOCCOCCOCCOCCOCOCOCCGOCCOCCOCSGOCOCCOCCCCOCC 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


5 كتب برنامج لقراءة مصفوفة ثنائية مكونة من م عنصر ثم قم بتصفير العناصر 
الواقعة تحت القطر الرئيسي ثم قم بطباعتها ؟ 
for (i=0;i<n;i++)‏ 
for (j=0;]<n; j++)‏ 
([<1) 1£ 
ziroup [i] [jJ]=0;‏ 


6)اكتب برنامج لقراءة مصفوفة ثنائية مكونة من م عنصر ثم قم بتصفير العناصر 
الواقعة فوق القطر الرئيسي ثم قم بطباعتها ؟ وظيفة 

for (i=0;i<n;i++) 

for (j=0;]<n; j++) 


ا 
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محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


7كتب برنامج لقراءة مصفوفة ثنائية مكونة من م عنصر ثم قم بتصفير العناصر 
الواقعة تحت القطر الثانوي ثم قم بطباعتها ؟ 
for (i=0;i<n;i++)‏ 
for (]J=0;]<n;J++)‏ 
if (i+j>=n)‏ 
ziro2 [i] [j]=0;‏ 


8 كتب برنامج لقراءة مصفوفة ثنائية مكونة من م عنصر ثم قم بتصفير العناصر 
الواقعة فوق القطر الثانوي ثم قم بطباعتها ؟ وظيفة 

for (i=0;i<n;i++) 
for (j=0;]<n; j++) 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


9)اكتب برنامج لقراءة مصفوفة ثنائية مكونة من " عنصر ثم قم بالبحث عن عنصر 
مدخل هل هو موجود او غير موجود ضمن عناصر المصفوفة؟ 
int search [100] [100];‏ 
int i,j]j,m,n;‏ 
cout<<"insert n:\n";‏ 
cin>>n;‏ 
COUIE<<"\nN-= === \n";‏ 
cout<<"insert array:\n";‏ 
for ( i = 0; i < n; i++ )‏ 


{ 
for ( j] = 0; j < n; J++ ) 
{ 
cout << "[" << i << "][ "<< j<< "]: "; 
cin>>search[ i ][ j] ] ; 
cout << endl; 
} 
} 
coUut<<" \n-=-=-—-——————=—=—===—=—=—-—-—-——- \n"; 
int b,k; 
cout<<"insert search k'"; 
cin>>k; 
b=0; 
COUI<< "(N= === \n"; 


for (i=0; (i<n) && (b==0) ;i++) 
for(j=0; (j<n) && (b==0) ; j++) 
if (search[i] []J]]==k) 


b++; 

if (b==0) 

cout<<"not found"<<endl; 
else 


cout<<" found"<<endl ; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


0)برنامج يقوم بقراءة مصفوفة ثنائية مكونة من ١N‏ عنصر ثم طباعة الإعداد 
الفردية وتصفير الأعداد الزوجية ؟ والعكس وظيفة 


for (i=0;i<n;i++) 

for (j=0;]<n;jJ++) 

if (al[i][j]Š 2==0) 
ali] [j]=0; 


/fif (a[i][j]% 2!=0) 


1)برنامج يقوم بقراءة مصفوفة ثنائية مكونة من ١N‏ عنصر ثم طباعة الإعداد 
الزوجية وتصفير الأعداد الفردية ؟ وظيفة 
12)برنامج يقوم بقراءة مصفوفة ثنائية مكونة من ١‏ عنصر ثم طباعة الأعداد 
التي تقع في المواقع الزوجية (اى مجموع موقع الصف مع العمود زوجي وتصفير 
الأعداد الأخرى ؟ والعكس وظيفة 


for (i=0;i<n;i++) 
for(j=0;]<n;j]++) 
if ))1+[( 5 2==0( 
ali] [j]=0; 


// if ((i+j)% 2!=0) 


3) برنامج يقوم بقراءة مصفوفة ثنائية مكونة من ١‏ عنصر بحيث يكون الإدخال 
من الصف الأخير ثم الصف الذي قبل الأخير وهكذا ثم طباعة ؟ 


int a[100] [100]; 
int i,j]J,m,n; 
cout<<"insert n:\n"; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cin>>n; 

COULCST (miu \n"; 
cout<<"insert array:\n"; 

for ( i = n; i>= 1; --31 )( 

{ 


for ( ] = 1; ] <= n; ]J++ ) 

{ 

cout<< "[" << i << "][ "<< j<< "]: "; 
cin>>a[ i ][ J ] ; 
cout << endl; 


} 
} 
coUut<<"\n-==-=—=-—=————=—=-==-=====-- \n"; 
for ( i =1; i <= n; i++ ) 
{ 
cout << "[ " << i << "]: "; 
for ( j] = 1; j] <= n; j++ ) 
cout<<'\t' << al[ i ][ j ] << " "; 
cout << endl; 
} 


4) برنامج يقوم بقراءة مصفوفة ثنائية مكونة من ١‏ عنصر بحيث يكون الإدخال 
من الصف الأول من البدائية ثم الصف الثاني من الأخير وهكذا .... ثم طباعة 


المصفوفة ؟ 
cout<<"\n-==-=-—=-=——=——=—=—=======-- \n";‏ 
cout<<"insert array:\n";‏ 
int c=0;‏ 
for ( i = 1; i<= n;i++ )‏ 
{ 


for ( j] = 1; j] <= n; j++ ) 
{ 


if (1%52!1=0( 

c+=1; 
cout<<" [" << i << "][ "<< c<< "]: "; 
cin>>al i ][ € |] ; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout << endl; 
1Ê )152==0( 
c-=1; 


} 


cout<<"\n ا ا ا ا ا‎ \n" 


| الإدخال من العمود الأخير للصف الأول وهكذ‎ 5 
for ( i = 1; i<= n;i++ ) 
{ 
for ( ] = n; ] >= 1; 7-- ( 
{ 
cout << "[" << i << "][ "<< j<< "]: "; 
cin>>a[ i ][ J ] ; 
cout << endl; 


} 
} 
6) الإدخال من العمود الأخير بدء من الصف الأخير ثم العمود الثاني وهكذا 
for ( i = n; i>= 1;i-- )‏ 
{ 


for ( ] = n; ] >= 1; 3-- ( 
{ 
cout << "[" << i << "][ "<< j<< "]: "; 
cin>>a[ J ][ i ] ; 
cout << endl; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


7) الإدخال من العمود الأول بدء من الصف الأخير ثم العمود الثاني وهكذا 
for ( i = 1; i<= n;i++ )‏ 
{ 
for ( ] = n; ] >= 1; 73-- (‏ 
{ 
cout<< "[" << i << "][ "<< j<< "]: ";‏ 
cin>>a[jJ][ i ] ;‏ 
cout << endl;‏ 


8) برنامج يقوم بقراءة مصفوفة ثنائية مكونة من N‏ ثم يقوم بحساب مجموع 
كل صف الى داخل مصفوفة ذات بعد واحد ثم طباعة المصفوفة والمجاميع ؟ 
int a[100] [100];‏ 
int sum [100];‏ 
int suma;‏ 
int i,j]j,m,n;‏ 
cout<<"insert n:\n";‏ 
cin>>n;‏ 
COUE<<" \n--=-=-—-—-—=——=—=—=—=—=—======—---- \n";‏ 
cout<<"insert array:\n";‏ 
for ( i = 1; i<= n; i++ )‏ 
{ 
suma=0 ;‏ 
for ( J] = 1; j] <= n; J++ )‏ 
{ 
cout << "[" << i << "][ "<< j]<< "]: ";‏ 
cin>>a[ i ][ J ] ;‏ 
cout << endl;‏ 
suma=suma+ta [i] [j] ;‏ 
} 


sum [i] =suma; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


} 
cout<<"\n ت‎ \n" 
for ( i =1; i <= n; i++ ) 
{ 

cout << "[ " << i << "]: "; 

for ( j] =1; j <= n; j++ ) 

cout <<'\t' << al[ i ][ j ] << " "; 
cout << endl; 

} 
cout<<"\n aa = \n" 
for ( int d = 1; d <= n; d++ ) 


cout <<'\t' <<sum[ d ] << " "; 
cout << endl; 


تمرین :) 

لدينا خمسة طلاب ولكل طالب منهم ثلاث درجات اكتب برنامج لقراءة درجات 
الطلاب الخمسة وتخزينه في مصفوفة ثنائية بحيث يحسب البرنامج مجموع درجات 
كل طالب من الطلاب الخمسة ثم تخزينها في مصفوفة أخرى ذات بعد واحد ومن 
ثم يرتبها ترتيب تنازلي بحيث يطبع البرنامج .... 

1- أعلى درجة من درجات الطلاب 

2- أعلى مجموع من مجاميع درجات الطلاب 

3- محتويات المصفوفة ذات البعدين 

4- محتويات المصفوفة ذات البعد الواحد ؟ 


9 برنامج يقوم بقراءة مصفوفة ثنائية مكونة من ١‏ عنصر ثم يقوم بحساب 
عدد الأعداد السالبة ثم طباعة العدد؟ 
int a[100] [100];‏ 
int i,j]j,m,n;‏ 
cout<<"insert n:\n";‏ 
cin>>n;‏ 
COUE<<"\n-=-=--—=——=—=——=—=—=—===-==-- NTF‏ 
cout<<"insert array:\n";‏ 
int count=0;‏ 
for ( i = 1; i<= n; i++ )‏ 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


{ 
for ( ] = 1; ] <= n; j++ ) 
{ 
cout << "[" << i << "][ "<< j]<< "]: "; 
cin>>a[ i ][ J ] ; 
if (al[i] [jJ] <0) 
count+=1; 
cout << endl; 
} 


} 
\n"‏ ا ا ا ا اا ااا cout<<"\n‏ 


cout << "[ " << count << "]: "; 
cout << endl; 
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0)برنامج يقوم بقراءة مصفوفة ثنائية مكونة من ١‏ عنصر ثم يقوم بحساب 
عدد الأعداد الفردية ثم طباعة العدد؟ 

1)برنامج يقوم بقراءة مصفوفة ثنائية مكونة من N‏ عنصر ثم يقوم بحساب 
عدد الأعداد الزوجية ثم طباعة العدد؟ 

منقول المصفوفة ثم طباعة المصفوفة ومنقول المصفوفة؟ ما هو المنقول؟ 


int a[100] [100];int at[100] [100]; 
int i,j]j,m,n; 
cout<<"insert n:\n"; 
cin>>n; 
COUt<<"\N======—=—=———————————— \n"; 
cout<<"insert array:\n"; 
for ( i = 1; i<= n;i++ ) 
{ 

for ( ] = 1; ]J<= n; ]I++ ) 

{ 
cout << "[" << i << "][ "<< j<< "]: "; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cin>>a[ i ][ J ] ; 
atl j] Jli ]=al i ][ j] J]; 
cout << endl; 


} 
} 
COULCST" (Imi \n"; 
for ( i = 1; i <= n; i++ ) 
{ 
cout << "[ " << i << "]: "; 
for ( j] = 1; j <= n; j++ ) 
cout <<'\t' << al[ i ][ j ] << " "; 
cout << endl; 
} 
cout<<"\n----- EE \n" 
for ( i = 1; i <= n; i++ ) 
{ 


cout << "[ " << i << "]: "; 

for ( j] = 1; ] <= n; j++ ) 

cout <<'\t' << at[ i ][ j] ] << " "; 
cout << endl; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


كوز 1) ما هو ناتج تنفيذ البرنامج التالي؟ 
int a[5]={1,2,3,4,5};‏ 


int i; 
cout<<"\n ا ا ا ت ا اا‎ \n" 
for ( i=1l; i <= 5; i++ ) 
{ 

cout <<'\t' << a[5- i ] << " ";‏ 
} 
\n"‏ ااا اا ااا ااا اانا اا اناا تا cout<<"\n‏ 
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كوز2) ما هو ناتج تنفيذ البرنامج التالي؟ 
int a[5]={1,2,3,4,5};‏ 


int i; 
cout<<"\n ن ن ن ت ن ن ت ا‎ \n" 
for ( i= 5; i >= 1; i--) 
{ 
cout <<'\t' << a[i-1] << " "; 
} 
cout<<"\n ت‎ —--_ \n" 
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كوز3) ما هو ناتج تنفيذ البرنامج التالي؟ 
int a[5]={1,2,3,4,5};‏ 
int i;‏ 
COUE<S<"\n-====—=——————uu————— \n";‏ 
for ( i = 1; i <= 5; i++ )(‏ 
(152==0) 1£ 
cout <<'\t' << ali] << " ";‏ 
COUE<<"\n-====—=—————uuuu———— (n;‏ 
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محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


كوز4) ما هو ناتج تنفيذ البرنامج التالي؟ 
int a[5]={1,2,3,4,5};‏ 
int i;‏ 
\n"‏ ت ت ت cout<<" \n‏ 
for ( i = 5; ji >= 1; i--)‏ 
(1%2==0) ۴گ 
cout <<'\t' << ali] << " ";‏ 
\n"‏ ت ت ت cout<<" \n‏ 
كوز5) ما هو ناتج تنفيذ البرنامج التالي؟ 
int a[5]={1,2,3,4,5};‏ 


int i; 
int c=0; 
cOUt<<"\n-==—=—=———=—=—== \n"; 
for ( i = 5; ûi >= 1; ã--( 
if )1%2'=0( c+=1; 
cout <<'\t' << c << " ";, 


cout<<"\n ت ت ت ت ت ت ت ت ت‎ \n" 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 
)٦‏ اكتب برنامج يقوم ببناء المصفوفة الثنائية التالية (مصفوفة الواحد ):. 
int array1 [100] [100];‏ 


int i,j,n; 
cout<<"insert n:\n"; 


cin>>n; 
cout<<"\n--=----—-——-——-—- 
for ( i = 1; i <= n; 
{ 
for (j = 1; j <= n; j++ ) 
{ 
1٤۴ ([==ذ)‎ 
arrayl[ i ][ j ]=1; 
else 
arrayl[l i ][ j] ]=0; 
cout<<'\t' << arrayl[ i ][ j] ] ; 
} 
cout << endl; 
} 
COUtE<<" \n-==-=-—-—-————=-—==—==-=- \n"; 


۷) اكتب برنامج يقوم ببناء المصفوفة الثنائية التالية ( ):. 
int array1l [100] [100];‏ 
int i,j],n;‏ 
cout<<"insert n:\n";‏ 


cin>>n; 
cout<<"\n--=---—---—--- \n"; 
for ( i = 1; 1i <= n; 1++ ( 
{ 
for (j = 1 5 <= n; j++ ) 
{ 
1٤۴ ([==ذ)‎ 
arrayl[l i ][ j ]=i; 
else 


arrayl[ i ][ j] ]=0; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout <<'\t' << arrayl[ i ][ j] ] ; 


} 
cout << endl; 


} 
COUt<<"\n-=-=-=--—=——=——=—=—==-=- \n"; 


.:) ( اكتب برنامج يقوم ببناء المصفوفة الثنائية التالية‎ )٩ 
int array1l [100] [100]; 
int i,j],n; 
cout<<"insert n:\n"; 
cin>>n; 
cout<<"\n-----—-————-—- 
for ( i = 1; i <= n; 


{ 


for (] = 1; ] <= n; 
{ 
if (i+]==n+1) 
arrayl[ i ][ j ]=i; 
else 
arrayl[ i ][ j] ]=0; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout <<'\t' << arrayl[ i ][ j ] ; 
} 
cout << endl; 


} 
COUt<<" \n-==-=-—-—-————=--====-=- \n"; 


( اكتب برنامج يقوم ببناء المصفوفة الثنائية التالية‎ )١ 
int array1 [100] [100]; 
int ãi,j],n; 
cout<<"insert n:\n"; 
cin>>n; n"; 
= 1; ã <= n; i++ ) 


for ( i 
{ 
for (j = 1; j] <= n; j++ ) 
{ 
if (i+]==n+1) 
arrayl[ i ][ j] ]=j; 
else 
arrayl[ i ][ j] ]=0; 

cout <<'\t' << arrayl[ i ][ j] ] ; 
} 
cout << endl; 

} 

cout<<"\n ی‎  ک‎ \n" 


.:) ( اكتب برنامج يقوم ببناء المصفوفة الثنائية التالية‎ )١ 
int array1 [100] [100]; 
int ãi,j],n; 
cout<<"insert n:\n"; 


cin>>n; 

cout<<"\n ا ا‎ \n" 
for (i = 1; ûi <= n; i++ ) 
{ 


for (] = 1; ] <= n; 
{ 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


ے٤‎ )1<=[( 
arrayl[l i ][ j ]=i; 
else 
arrayl[ i ][ j] ]=0; 
cout <<'\t' << arrayl[ i ][ j] ] ; 
} 
cout << endl; 


} 
COUtE<<" \n-=-=-—-—————=-=====- \n"; 


.:) ( اكتب برنامج يقوم ببناء المصفوفة الثنائية التالية‎ )١ 
int array1 [100] [100]; 
int ãi,j],n; 
cout<<"insert n:\n"; 


cin>>n; 

cout<<"\n------- \n"; 

for ( i = 1; i <= n; i++ ) 
{ 


for (j = 1; j] <= n; j++ ) 


arrayl[l i ][ j ]=i+j; 
cout <<'\t' << arrayl[ i ][ j] ] ; 
} 
cout << endl; 


} 
CcCOoOUt<<"\n-==-=--—-———=—=—=—==-=- \n"; 
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محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


۳) اكتب برنامج يقوم ببناء المصفوفة الثنائية التالية 


©©©®®®CcCcCCCCCCCCCOCCCCCCOCCCCCOCCCCCCCCCCCCCCCOCCOCCOCCCCOCOCOCCCOCCCCCCCCCCCCCC: 


٤‏ ) الدوال :. برنامج يطبع رسالة ثلاثة مرات باستحدام الدوال ؟ موضوع 
المحاظرة القادمة انشاء الله ؟ حضر 


#include<iostream> 
using namespace std; 


vOid wel () 


{ 
cout<<"hello"<<endl; 


void main () 
{ 
wel () ; 
wel () ; 
wel () ; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


} 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المحاضرة الدوال مہہoناعرu؟‏ :. 


تعريف الدالة » انواع الدوال » اهمية الدوال - برامج متعدده - الدوال التعاودية 
۶ 


لايعيد قيمة ولإيحتاج الى معلومات . 

لايعيد قيمة ويحتاج الى معلومات 
بعبد قيمة ولايحتاج الى معلومات . 
يعيد قيمةايحتاج الى معلومات . 


.١‏ اكتب التابع )[اںوم8 الذي يأخذ علامة طالب ويحدد إذا كان الطالب 
(ناجج) ام (لا) (اكبر من 50 ناجج ). 
تمرين :اكتب التابع )اںءه8 الذي يأخذ علامة طالب في مادة ويحدد إذا كان 
الدرجة (ممتاز او جيد جداً او جيد او مقبول او ضعيف) . 
#include<iostream>‏ 
using namespace std;‏ 


void result(int x) 
{ 
if (x>=50) 
cout<<"pass"<<endl ; 
else 
cout<<"fail"<<endl; 


void main () 
{ 
int grade; 
cin>>grade; 
result (grade) ; 
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2 .اكتب التابع ع۷٥41‏ الذي يحدد العدد زوجي او فردي. 
تمرين: اكتب التابع ا)وعع. الذي يحدد العدد موجب او سالب. 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


void oddeven (int x) 


{ 
if )×52==0( 
cout<<"Even"<<endl; 
else 
cout<<"odd"<<endl; 
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۳ ,اکتب التابع sqr‏ الذي يعطي مربع العدد . 
تمرين: اكتب التابع ۲3ء الذي يعطي مكعب العدد. تمرين: اكتب التابع 
ع الذي يحدد إذا كان العدد أولي. 
void sqr (int x)‏ 
{ 
cout<<x*x<<endl ;‏ 


لايعبد قبمة ولايحتا ج الى معلومات ٤‏ 
4. اكتب التابع امس الذي لايعيد قيمة ولايحتاج الى معلومات . 
vOid wel ()‏ 


{ 
cout<<"hello"<<endl; 
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يعيد قيمة ولايحتاج الى معلومات . 


float time (void) 
. .اكتب التابع إيء الذي يعطي مربع العدد . يعيد قيمة يحتاج الى معلومات‎ 5 
int sqr (int x) 
{ 


return x*x; 
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محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


6.اکتب. 
void max ()‏ 
{ 
1f (x1>y1)‏ 
cout<<x1<<endl ;‏ 
else‏ 
cout<<y1<<endl;‏ 


7.اكتب التابع رإإوم ,إةلهءء يقوم بطباعة عناصر مصفوفة ذات بعد 
واحد وكذلك تابع يعمل على ادخال عناصر الي مصفوفة ذات بعد واحد . 
#include<iostream>‏ 
using namespace std;‏ 


int i,s; 
int x[100]; 


void parry(int a[],int n) 
الطباعة//‎ 

{ 

cout<<"\n THE ARRAY \n"; 

for (i=1 ; i<=n; i++) 

cout<<a [3i] ; 

cout<<endl ; 

} 


vOid readar (int a[],int n) 
// الادخال‎ 
{ 
cout<<"\nINSERT ARRAY:\n"; 
for (i=1 ;i<=n;i++) 
{ 
cout<<"x ["<<i<< "]:"; 
cin>>a[i]; 
cout<<endl ; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


} 
} 
void main () 
{ 
cin>>s; 
readar (x,s) ; ا لاستدعاء‎ 
parry (x,s); ا لاستدعاء‎ 
} 


۸ .اكتب التابع × يقوم بأيجاد اكبر عنصر من عناصر مصفوفة 
vOid max(int a[],int n)‏ 
{ 
int m;‏ 
m=a [0] ;‏ 
for (i=1; i<=n; i++)‏ 
if (m<a[3i])‏ 
m=a [i] ;‏ 
cout<<m;‏ 
cout<<endl ;‏ 
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9 .اكتب التابع 1 يقوم بأيجاد اصغر عنصر من عناصر مصفوفة 
0 .اكتب التابع ٤ات‏ يقوم بأيجاد بترتيب عناصر مصفوفة 
1اكتب التابع 1ء د٠ء‏ يقوم بالبحث عن عنصر في عناصر مصفوفة 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


2 ) اكتب برنامج عام يقوم بتنفيذ الدوال السابقة ( ادخال عناصر الى 
مصفوفة ‏ طباعة - ايجاد اكبر عنصر) بی واد 


#include<iostream> 

using namespace std; 

int i,s; 

int x[100]; 

د الة ادخال عناصر الى مصفوفة <====د// 
void parry (int a[],int n)‏ 
{ 

cout<<"\n THE ARRAY \n"; 
for (i=1 ; i<=n; i++) 
cout<<a [3i] ; 

cout<<endl ; 


/ /======== د الة طباعة عناصر مصفوفة‎ 
void readar (int a[],int n) 
{ 
cout<<"\nINSERT ARRAY: \n"; 
for (i=1 ;i<=n;i++) 
{ 
cout<<"x ["<<i<< "1:"; 
cin>>a [i]; 
cout<<endl ; 


د الة ايجاد اكير عنصر في مصفوفة ====== | / 
vOid max(int a[],int n)‏ 

{ 

int m; 
m=a [0] ; 

for (i=1; i<=n; i1i++) 

if (m<a[3i]) 

m=a [i]; 

cout<<m; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout<<endl; 


void main () 

{ 

بداية البرنامج الرئيسي // 

char c1; 
do 
{ 

// بداية الحلقة‎ 
cout<<"\n1) -INSERT NEW ARRAY\n2) -PRINT 


ARRAY" 
<<"\n3) -MAX NUMBER\n0O) EXIT\n" ; 
cin>>cl; 
switch (c1) 
{ 
case '1': 
{ 
cout<<"\nINSERT LENGTH:";, 
cin>>s; 
readar (x,s) ; 
break; 
} 
case '2' 
{ 
if (s==0) 
{cout<<"\n ERROR\n" ; 
break; } 
else 
parry (x,s) ; 
break; 
} 
case '3' 


cout<<"\n MAX NUMBER IS:"; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


max (x,s) ; 
break; 
} 
default: 


{ 
cout<<" \nERROR" 


} 

} 

هل نهاية الحلقة // 
while (c1!='0');‏ 


} 
تهات ايرا 77 
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محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


الوقت ربع ساعة فقط 
كوز1: 
أ- إذا كان لدينا عشر دول عربية و في ثلاثة أيام مختلفة مستقلة تم رصد درجات 
E ASE‏ 
ا اكثف شفرة تقوم ترف مضفرة للجم اكور ة ساقا ٠‏ 
۲. اکتب شفرة تقوم بإسناد درجة الحرارة لكل دولة في اليوم الثالث فقط إلى 
المصفوفة المعرفة في الفقرة الأولى؟ 
۳. اكتب شفرة تقوم بطباعة درجة الحرارة لجميع الدول في اليوم الثالث فقط التي 
تم إسنادها إلي المصفوفة في الفقرة الثانية ؟ 
.٤‏ اكتب شفرة تقوم بإيجاد اكبر درجة حرارة لليوم الثالث فقط من المصفوفة 
السابقة ؟ 
كوز2: ما ناتج تنفيذ البرنامج التالي: 
#include<iostream>‏ 
using namespace std;‏ 
void main ()‏ 
{ 
int array1 [100] [100];‏ 
Int Ty J ;D;‏ 
cout<<"insert n:\n";‏ 


cin>>n; N=5 لماً ان المتغيبر‎ 
COUtE<<" \n--=-=-—-—-———---===-=- \n"; 
{ 


for (] = 1; ] <= n; ]J++ ) 
{ 
1٤۴ ([==ذ)‎ 
arrayl[ i ][ j ]=j; 
else if (i+j==n+1) 
arrcayl[ i ][ ] ]=i; 
else 
arrayl[ i ][ j] ]=0; 
cout <<'\t' << arrayl[ i ][ j] ] ; 
} 
cout << endl; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


} 
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الوقت ربع ساعة فقط 
كوز1: 


ا إذا كان لدينا عشر دول عربية و في ثلاثة أيام مختلفة مستقلة تم رصد درجات 
EEL‏ المطلوب:. 
.٥ :‏ اكتب شفرة تقوم بتعريف مصفوفة للجملة المذكورة سابقا ؟ 
“. اكتب شفرة تقوم بإسناد درجة الحرارة لكل دولة في اليوم الأول فقط إلى 
المصفوفة المعرفة في الفقرة الأولى؟ 
۷. اكتب شفرة تقوم بطباعة درجة الحرارة لجميع الدول في اليوم الأول فقط التي 
تم إسنادها إلي المصفوفة في الفقرة الثانية ؟ 
۸. اكتب شفرة تقوم بإيجاد اكبر درجة حرارة لليوم الأول فقط من المصفوفة 
السابقة ؟ 


كوز2: ما ناتج تنفيذ البرنامج التالي: 

#include<iostream> 

using namespace std; 

void main () 

{ 

int array1 [100] [100]; 

int ãi,j],n; 

cout<<"insert n:\n"; 


لما ان المتغير cin>>n; N=5‏ 
\n";‏ ت ت ت cout<<"\n‏ 

for ( i = 1; i <= n; i++ ) 

{ 


for (j = 1; ] <= n; j++ ) 
{ 
1٤ ([==ذ)‎ 
arrayl[ i ][ j] ]=i; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


else if (i+j==n+1) 
arrayl[ i ][ j ]=j; 
else 
arrayl[ i ][ j] ]=0; 
cout <<'\t' << arrayl[ i ][ j] ] ; 
} 
cout << endl; 


} } 
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الوقت ربع ساعة فقط 
کوز1: 


ا إذا كان لدينا عشر دول عربية و في ثلاثة أيام مختلفة مستقلة تم رصد درجات 
الحرارة لكل دولة في كل يوم المطلوب:. [ 
۹. اكتب شفرة تقوم بتعريف مصفوفة للجملة المذكورة سابقا ؟ 
.٠١‏ اكتب شفرة تقوم بإسناد درجة الحرارة لكل دولة في اليوم الثاني فقط إلى 
المصفوفة المعرفة في الفقرة الأولى؟ 
.١‏ اكتب شفرة تقوم بطباعة درجة الحرارة لجميع الدول في اليوم الثاني فقط 
التي تم إسنادها إلي المصفوفة في الفقرة الثانية 
۲. اكتب شفرة تقوم بايجاد اكبر درجة حرارة لليوم الثاني فقط من المصفوفة 
السابقة ؟ 
كوز2: ما ناتج تنفيذ البرنامج التالي: 
#include<iostream>‏ 
using namespace std;‏ 
void main ()‏ 
{ 
int array1l [100] [100];‏ 
int i,j],n;‏ 
cout<<"insert n:\n";‏ 


cin>>n; N١N=5 علماً ان المتغير‎ 
for ( i = 1; i <= n; i++ ) 
{ 


for (j = n; ] >= 1; ]-- ) 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


{ 
ے٤ ([==ذ)‎ 
arrayll i ][ j ]=i; 
else if (i+j==n+1) 
array1l[ i ][ j ]=j; 
else 
arrayl[ i ][ j] ]=0; 
cout <<'\t' << arrayl[ i ][ j] ] ; 
} 
cout << endl; 


FF 
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محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المحاضرة الدوال مارگ :. 
الدوال التعاودية ؛ 
1) اكتب التابع )ءج تعمل علي ايجاد المضروب لعدد مدخل 


#include<iostream> 
using namespace std; 


int fact(int n) 
{ 
int i1i,f; 
if (! (n>1) ) 
return 1; 
return (n*fact(n-1) ); 


void main () 

{ int n,f; 

cout<<"\ninsert n \n"; 
cin>>n; 

f=fact (n) ; 
cout<<"resault:"<<f<<endl ; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


2) اكتب التابع ٤ه‏ تعمل علي ايجاد المضروب لعدد مدخل 


#include<iostream> 
using namespace std; 


int fact(int n) 
{ 

int i,f; 
if (n>1) 
f=n*fact (n-1) ; 
else 
f=1; 
return (f) ; 


void main () 

{ int n,f; 

cout<<"\ninsert n \n"; 
cin>>n; 

f=fact (n) ; 
cout<<"resault:"<<f<<endl ; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


G3‏ اكتب التابع fact‏ تعمل علي ايجاد المضروب لعدد مدخل 


#include<iostream> 
using namespace std; 


int fact(int n) 
{ 
int i1i,f; 
f= (n>1) ?n*fact (n-1) :1; 
return (f) ; 


void main () 

{ int n,f; 

cout<<"\ninsert n \n"; 
cin>>n; 

f=fact (n) ; 
cout<<"resault:"<<f<<endl ; 
} 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


4 اكتب التابع Êإمسهم‏ دالة تعمل علي ايجاد القوة اي"× مدخلة 


#include<iostream> 
using namespace std; 


int powerf (int x,int n)// 
{ 

int Pp; 

if (n==0) 

return (1) ; 

p=x*powerf (x,n-1) ; 
return (Pp) ; 


void main () 

{ int x,n,p; 
cout<<"\ninsert x,n \n"; 
cin>>x>>n; 

p=powerf (x,n); 
cout<<"\npower :"<<p<<"\n"; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


5 اكتب التابع nںء‏ دالة تعمل علي حساب المجموع 1 الى ان" مدخلة 


#include<iostream> 
using namespace std; 


int sum(int n) // 
{int s; 

if (n==1)( 

return (1) ; 

else 

return (n+sum (n-1) ) ; 


void main () 

{ int n,s; 

cout<<"\ninsert n \n"; 
cin>>n; 

s=sum (n) ; 

cout<<"resault: "<<s<<"\n"; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


6) اكتب التوابع التالية التى تقوم بطباعة الاشكال الموضحة في التنفيذ. 
#include<iostream>‏ 
using namespace std;‏ 


E CWindous\systemd2\cmd exe 


insert the nunher4 
void v1(int n) * 


{ 
for( int i = 1 ; i <= n ; i++) 
{ 
for( int ] = 1; j] <= i ; 
cout<<"*"; 
cout<<endl ; 


void v2(int n) 
{ 
for(int i =n ; i >= 1; 
{ 
for( int j] = 1 ; j <= i ; ]++) 
cout<<"*"; 
cout<<endl ; 


ny key to continue ... „ 


1 < EET 


void v3(int n) 
{ 
for(int i=n;i>=1;1i--) 
{ 
cout<<" "; 
for(int j=i;j]<=n;]J++) 
cout<<]<<" "; 
cout<<endl ; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


void v4(int n) 
{ 
for (int i=n;i>=1;1i--) 
{ 
for(int j=i;j<=n;j]++) 
cout<<i<<" "; 
cout<<endl ; 


void v5(int n) 
{ 
for(int i=1;i<=n;i++) 
{ 
int k=i; 
for(int j=1;j<=n; j++) 
{ 
if (k==n+1) 
k=1; 
cout<<k<<" "; 
k+=1; 
} 
cout<<endl ; 


void v6(int n) 
{ 
for (int i=1;i<=n;i++) 
{ 
for(int j=1;j<=i;j]++) 
cout<<]j<<" "; 
cout<<endl; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


void main () 

{ 

int m; 

cout<<"insert the number"; 

cin>>m; 

v1 (m) ; 

COUT "<<endl ; 
v2 (m) 7 

COUT SS "<<endl ; 


COU "<<endl; 
v4 (m) ; 

COULSE SS "<<endl; 
v5 (m) ; 

COU "<<endl; 
v6 (m) 7 
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#include<iostream> 
using namespace std; 


int square( int xX ) 
{ 
cout<<"square of integer " << x << " is "; 
return xX * x; 


double square( double y ) 


{ 
cout<< "square of double " << y << " is "; 


return Y * YY; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


square( 7 ); 
endl; 

square( 7.5 ); 
endl; 


integer 7 is 49 
double 7.5 is 56.25 


void main () 


<< 
<< 
<< 
<< 


{ 
cout 
cout 
cout 
cout 

} 
/ /square 
/ /square 


©©O®®®®O®CGCNCGOGCOCCOCCOCCOCCOCCOCOCOCCOCCOCOCCOCCOCOCOCGOCCOCCOCSCOCOCCCCCOCC 


برنامج شامل تطبيق المصفوفات باستخدام الدوال// 


#include<iostream> 
using namespace std; 


int jJ,i,s; 


int x[100] [100]; 


void print2 (int a[] [100],int n) 


{ 


cout<<"\n THE ARRAY \n"; 


i<=n; i++) 


for (i=1 ; 


{ 


cout << "[ " << i << "]: "; 

for (j=1 
cout <<'\t' << al i ][ j ] << " "; 
cout << endl; 


; J<=n; 3J++) 


void readar2 (int a[] [100],int n) 


{ 


cout<<"\nINSERT ARRAY: \n"; 
for (i=1 ;i<=n;i++) 
j<=n; j++) 


for (]j=1 ; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


{ 

cout<<"x ["<<i<<","<<j<< "]:"; 
cin>>a[i] [j]; 

cout<<endl ; 


void max2 (int a[] [100],int n) 
{ 
int m; 
m=a [0] [0]; 
for (i=1; i<=n; 1++) 
for (]j=1 ; j]<=n; J++) 
if (m<al[i][j]) 
m=a [i] [j]; 
cout<<m; 
cout<<endl ; 


void ziroldo(int a[] [100],int n) 
{ 

for (i=1;i<=n;i++) 

for (j=1;]<=n; j++) 

1٤ )1<[( 

ali] [j]=0; 


void main () 
{ 
char c1; 
do 
{ 
cout<<"\n1) -INSERT NEW ARRAY\n2) -PRINT 
ARRAY" 
<<" \n4) -MAX NUMBER\n 3) ziroldo \n0)EXIT\n"; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cin>>c1l; 
switch (c1) 
{ 
case '1': 
{ 
cout<<"\nINSERT LENGTH:"; 
cin>>s; 
readar2 (x,s) ; 
break; 
} 
case '2': 
{ 
Ê )s5==0( 
{cout<<"\n ERROR\n"; 
break; } 
else 
print2 (x,s); 
break; 
} 
case '3' 
{ 
cout<<"\n ziroldo IS:"; 
ziroldo (x,s) ; 
break; 
} 
case '4' 
{ 
cout<<"\n MAX NUMBER IS:"; 
max2 (x,s) ; 
break; 
} 
default: 


{ 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout<<" \nERROR" 


} 
} 

while (c1!='0'); 

} 

نهاية البرنامج الشامل// 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


تطبيقات 
ماهو ناتج 
)1 
#include<iostream>‏ 
using namespace std;‏ 
void main ()‏ 


{ 


int n; 

cout<<"insert the number"; 

cin>>n; 

for( int i= n; i >= 1 ;i--) 
{ 


for( int ]J=1 ; ] <=i; j]++) 

cout<<"*"; 

for(int h=1; h <= 2*(n-i) ;h++) 
cout<<" "; 

for( int k =1 ; k <=i ;k++) 
cout<<"*"; 

cout<<"\n"; 


2( ماهو ناتج‎ 
#include<iostream> 
using namespace std; 
void main () 

{ 

for ( int i = 99; i >= 0; i -= 11 ) 
cout<<i<<endl; 

} 

3( ماهو ناتج‎ 
#include<iostream> 
using namespace std; 
void main () 


{ 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


int a[5]={5,4,3,2,1}; 
int i; 
COUIE<<" \n-= === \n" 
for ( i =1; i <= 5; i++ ) 
1£ )1%2==0( 
cout <<'\t' << ali] << " "; 
cout<<"\n-=-=—=—=————=—=-=====--—-—- \n" 


©©© OCOCCOCCOCCOCCOCCOCOCOCCOCCOCOCCOCCOCOCOCOCGOCCOCSGOCOCOCCCCOCO 


ماهو ناتج(4 
#include<iostream>‏ 
using namespace std;‏ 
void main ()‏ 
{ 
int i,j],n;‏ 
cout<<"insert n";‏ 
cin>>n;‏ 
for (i=n;1i>=1;1--)‏ 
{ 
for (j]j=1;]>=1;]--)‏ 
cout<<]<<" ";‏ 
cout<<endl ;‏ 


©©© OCGCOCCOCCOCCOCCOCOCOCCOCCOCOCCOCCCOCOCOCOCCOCCOCSGOCOCOCCCCCCO 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


تمرین: 

1 لدينا تسعة طلاب ولكل طالب منهم ثلاث درجات اكتب برنامج لقراءة درجات 
الطلاب التسعة وتخزينه في مصفوفة ثنائية بحيث يحسب البرنامج مجموع درجات 
كل طالب من الطلاب الخمسة ثم تخزينها في مصفوفة أخرى ذات بعد واحد ومن 
ثم يرتبها ترتيب تنازلي بحيث يطبع البرنامج ( 

1- أعلى درجة من درجات الطلاب 

2- أعلى مجموع من مجاميع درجات الطلاب 

3- محتويات المصفوفة ذات البعدين 

4- محتويات المصفوفة ذات البعد الواحد ؟ 


©©O®®®GOCCGOCCOCOCCOCCOCCOCCOCCOCOCOCCOCCOCOCCOCCOCOCOCOCCOCSGOCCOCCOCCCCCOCO 


2)اكتب برنامج يقوم ببناء المصفوفة الثنائية التالية 


3 كتب التابع )[ںءم8 الذي يأخذ علامة طالب في مادة ويحدد إذا كان الدرجة 
(ممتاز او جید جداً او جید او مقبول او ضعیف) . 


©W©O®GOCCGCOCCGOCCOCCCCCCCCOCOCOCCCCCCCCCCCCCOCCCOCCCCOCCCCCCCCCCCGCCCCOCCCCCCCC 
OOOO 


١‏ إذا كان لدينا عشر مدن يمنية و في ثلاثة أيام مختلفة مستقلة تم رصد درجات 
الحرارة لكل مدينة في كل يوم المطلوب:. [ 
ه اكتب شفرة تقوم بتعريف مصفوفة للجملة المذكورة سابقا ؟ 
© اكتب شفرة تقوم باسناد درجة الحرارة لكل مدينة في اليوم الثاني فقط 
إلى المصفوفة المعرفة في الفقرة الأولى؟ 
© اكتب شفرة تقوم بطباعة درجة الحرارة لجميع المدن في اليوم الثاني فقط 
التي تم إسنادها إلي المصفوفة في الفقرة الثانية ؟ 
اكتب شفرة تقوم بإيجاد اكبر درجة حرارة لليوم الثاني فقط من المصفوفة 
السابقة ؟ 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


المحاضرة _ السجلات خعuإخء‏ (مقدمة للبرمجة 2) 


الراب وع ں sir u)‏ : 


الي اهمه الثراكبب للعريف ملغيرات بطر مخئلفة عن الطرى المعهودة سابقا فق نحناج ان عبر عن شئ له 
اکر من مغر او انه لېس له لوغ پپاني محدد مثلا لو كلت تعمل في محل واحنجت ان تعجر عن سلعك الععروضه 
نكل سلعة لها اسم وسعر ورم تسلسلي و منشا ملا أكبف ستعرف السلعةً الواحدة هل ستعرفها من النوع 
الرمزي ام الصحيح ام الحفيئي ام ... ثالث تاج هنا الى اللعامل مع ار من نوع بباني للسلعة الراحدة 


1 a ی‎ e A Ê Î 1 E 
, و الثرکب بمفهومه العام هو الفبد لهو بعر عن عده الراع ببالبه مجموعه نحن نعربف راض‎ 


ا لصبغة العامة : 


struct names { 
elêmentl; 
elementa; 


element3; 


۲ : هي كلمة محجوزة للدلالة على انك تعلن عن ركيب 

8 : هو الاسم الذي لريد ان لطلفه على الذركيب وهو أي اسم خاضع لفراعد اللسمبة ويمكن في بعض 
الاحیان اهماله كما سبائى لاحفا , 

مم : هو اللوع البباني الذي ستعرف فيه عناصر الئركيب كان يكون ۲ ,أ١‏ أ, 0| او غيرها, _ 
1 : هو العنصر المراد تعربفه وهو پمکن ان پکون آي اسم تضعه شرط ان لا پکون كلمة محجوزة [أي 
انه المنغير الأي سيتون علاصر الأركبب) ولعد غير محدد من الطاصر وحسب حاجلك , 

1زط0 : هي معرٺات من نوع هذا الئرکيب( وهي هنا اخياري) ويمكن تعريفها في هذا الموضع 
مباشرة او داخل الدالة الرليسية كانها مغر من نوع ركب , 


بع الأركيب بين جزء ملفات الهبدر وهاأ؟ ههه" وبين جزء الإعلان عن الداله الرليسبة 


struct student 


char name [10]; 
int deg; 
}; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout<<s.name ; 


cout<<s [ J] .name; 
ادخال قيم من لوحة المفاتيح الى السجلات.‎ 3 
cin>>s.name; 


cin>>s [i] .name 


رک و الات رد بال 


#include<iostream> 
using namespace std; 


struct student 


{ 


char name [10] ; 


int deg; 

}; 
/ /=========== == 
int i, j] , n; 
/ / === ====== == === 

void main () 

{ 
/ | == ==== === === == 
student s[10],t; 
/ /========== === 
cout<<"insert n:"; 
cin>>n; 
/ | ============= 


for( i= 0; i <= n ; i++) 


cin>>s [i1] .name; 
cin>>s [i] .deg; 
} 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


for ( i=0 ;i<=n; i++) 
for ( jJ=i+1;]<=n;]++) 

if (s[i].deg <s[j] .deg ) 
{ 

t=s [i]; 

s[i]=s[]]; 

s[j]=t; 


cout<<s [ jJ] .name; 
cout<<s [ J] .deg; 
cout<<endl ; 


t=s [0]; 

for( i=0; i<=n; i++) 

if (t.deg<s[i] .deg ) 

t=s [i]; 

cout<<t.name<<t. deg<<endl ; 


#include<iostream> 
using namespace std; 
struct date 

{ 

int day; 

int month; 

int yaer; 

}; 


struct student 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


char name [10]; 
date datee; 
}st; 
void main () 
{ 
cin>>st.name; 
cin>>st.datee.day>>st.datee.month>>st.d 
atee.yaer; 
cout<<st.name<<" 
"<<st.datee.day<<"/"<<st.datee.month<<"/"<< 
st.datee.yaer<<endl; 


} 


#include<iostream> 
using namespace std; 
struct date 
{ 
int day; 
int month; 
int yaer; 
}; 
struct student 
{ 
char name [10] ; 
date datee; 
}st[20]; 
int 1,J,n; 
void main () 
{ 
cin>>n; 
for (i=0;i<n;i++) 
{ 


cin>>st [i1] .name; 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cin>>st[i] .datee.day>>st[i] .datee.month>>st 
[i] .datee.yaer; 


for (i=0;i<n;3i++) 
for (j]=i+1;]<n; j++) 
if (strcmp (st[i] .name,st[ j] .name) >0) 
{ 
student tmp ; 
tmp=st [i] ; 
st[i]=st[j]; 
st[j]=tmp; 
} 
for (i=0;i<n;i++) 
cout<<st [i] .name<<""<<st [i] .datee.day<<"/"< 
<st[i] .datee.month<<"/"<<st [i] .datee.yaer<< 
endl; 


student max; 

max=st [0] ; 

for( i=0; i<=n; i++) 

1f (max.datee.yaer<st[i] .datee.yaer ) 
max=st [i]; 

cout<<max .name<<" 
"<<max.datee.day<<"/"<<max. datee.month<<" /" 
<<max.datee.yaer<<endl ; 


تمارين 


+ 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


1 نفذ برنامج لقراءة سجل لطالب (الاسم › المعدل) ثم طباعته مع التقدير. 
2) نفذ برنامج لقراءة سجل لموظف (الاسمءالراتب) ثم طباعته مع الصافي بعد 
استفطاع 415. 

3 نفذ برنامج لقراءة سجل لصنف (الاسم»السعرءالعدد) ثم طباعتها مع القيمة 


الاجمالية. 
4( نفك برنامج لقراءة سجل لماد ة(الاسم» درجة النظري»› درجة العملى) ثم طباعتها 
مع الدرجة العظمى. 


5) نفذ برنامج لقراءة سجل دين شخص (الاسم»له»عليه) ثم طباعته مع الصافي. 
6 نفذ برنامج لقراءة سجلات طلاب (الاسم › المعدل) ثم طباعته مع التقدير. 
7 نفذ برنامج لقراءة سجلات موظف (الاسمءالراتب) ثم طباعته مع الصافي بعد 
استفطاع 415. 

8 نفذ برنامج لقراءة سجلات صنف (الاسم»السعر٬العدد)‏ ثم طباعتها مع القيمة 


الاجمالية. 

09 نفذ برنامج لقراءة سجلات مادة(الاسم» درجة النظري» درجة العملى) ثم 
طباعتها مع الدرجة العظمى. 

0) نفذ برنامج لقراءة سجلات ديون اشخاص (لاسم»له»علیه) ثم طباعته مع 
الصافي. 


المؤ اشرات إهخ«ذهمط (مقدمة للبرمجة 2) 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


التعامل مع المؤاشرات ۶إointeمpم‏ في C++‏ 


1 مواقم الذاكرة 

يمكن أن تعقير تكل الذاكرة متل صتاديق البريد » حيت تمتل كل حانة موقع في الذاكرة و نقوم بتخزين قيمة 
وحلدة (قد تكون صحيحة اة أو حتيفة وه أو هطع) ء كل موقع قي الذاكرة له عنوان ء و يتم تمتيل عنارين 
لذاكرة باستخدام التظام الست عضري من باب التسهيل كون انه في الأسل يمتل باستخدام النظام التتائي ءقطى 
سبيل المتال لتمتيل الحانة رقم 15 باستخدام النظام التتنائى قإننا سوف نحتاج إلى اريع انات هى 1111 على 
عكين النظام الست عتري الذي يمتلها بخانة ولحدة هي ۴ . 


2 حجم الألماط في الذاكرة 


قل أن نخوض بالمؤشرات لا بد من التذكير بطريقة عنونة المتحولات بالذاكرة . 
عندما نقوم بتعريف المتحولات فى البرنامج ء قإنها تأحذ حيزاً قي الذاكرة بما يتتاسبا مع حجمها 


1 r | 
4 |] | 


4 [fat | 
8 [double | 


فسیتم حجز. 4 حجرات للمتحول F‏ وحجرة للمتحول € وحجرنین للمتحول 1 وسیکون تمتیلهم بالذاكرة على 
الكل التال 
ي 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


Address 


20004 
20005 
20006 
20007 
20008 
20009 
2000a 
2000b 
2000e 


3 الحجز الاستاتيكي 


فكما رأبيتا فإله يتم حجز حجم المتحولات بع انمطها وهذا الحجز يسمي بالحجز الساكن الستاتيكي ( ناا 
#ااونموه) ويوصف بالساكن لان الذاكرة المكرسة له تبقى محجوزة له طوال مدة لتفيذ البرنامج ,فالمترجم هنا 
يعرف تماما كمية الذاكرة التى تحتاجها المتحولات , ويخصبص المترجم حجرات المتحولات العامة والتوابتا ضمن 
مقط المعليات (امعسعمء واول) ومقطع المعطيات هذا عبارة عن مساحة من الذاكرة محدودة الطول , يدد 
ونقررحجمها المترجم بناء على عدد وتوع المتحولات العامة والتوابت المصرح عنها بالبرنامج , أما المتحولات 
المحلية (عااومه۷ لةءه]) والبارمترات فالمترجم يخصص ليا حجرات في الذاكرة عنما يتطاب تتفيذ البرنامج 
ذلك , وأكن يحجز المترجم بشكل أولي كمية من الذاكرة المكس (عاعها5)من أجل هن المتحولات -وطول مقطع 
المكس تابت ويحدد أثتاء الترجمة اليرنامج 2 
فالخانصة أن الحجز الستائيكي يتم تحديد كمية الناكرة المخصصة أتناء ترجمة البرنامج وقل تتفيذه ,لأن هذه الكمزة 
تابته لا نتخیر . 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


رض أنتا تريد يرنامج من أجل ترتيب معطيات عددية يدها المستخدم ولا أعرف هذه الكمية والكمية لست 
تابته فمن أجل نلك يوجد طريقين 
الأولى : أن أحجز مصفوفة ذاتا حجم كبير بحيت تكنى تخزين القيم المتوقعة وهنا سنحجز كمية كبيرة من الذاكرة 
عن طريق الحجز الاستاتيكى 
التانية : عن طريق استختام المؤترات والحجز الديناميكي 
إن اميد الأساسي للتعامل مع المتحرلات الديناميكية موتخصيص ذاكرة ديناميكية للبرنامج يتم الحجز ضمنها لهذه 
المتحرلات ولاستخدامها وبعد الاتتهاء ينم تحرير الحجز (إعادة الذاكرة المحجرزة لاستخدامات أخري ) فيما يعد. 
إا نحن الان سنتعامل مع طريقة جديدة مع الذاكرة وهي تخصيص حجرات الذاكرة أثناء التنفيذ (تنفيذ البرنامج ) 
وليس أثاء الترجمة (#اأسهء) ترجمة البرنامع . 
ولكن كيف بمسكنتا التعلمل هذه المتحر لات الديناميكية وكيفا سوفا تصرح عنها؟ 


تتم طريقة الحجز باستخدام مؤقرات (عنارين ) إلى التاكرة -الديناميكية -والتى تسى الكرمة مه116 وستتم بهذه 
الطريقة بسب قكرة الاخ والأعادة منها وإليها , والخلاصة أن استخدام المتحولات النيناميكية لا يتم مباشرة بل عن 
طرق مؤتر. 


5. ارين المتحولات في الذاكرة 


لكل حلية من خاثيا ذاكرة الحاسب عنوان محدد, والعنوان هو رقم يبدأ من 0 وينتهي بالقيمة العظمى لسعة الذاكرة. 
كي نستطيع ان تعرف عنوان متحول في الذاكرة تقوم بإضافة الإشارة & قبل المتحول و هي تعني عنوان المتحول 
)Address Of)‏ .لاحظ : 


#include<iostream> 

using namespace std; 

void main () 

{ 

int x; 

cout << "Enter Number: "; 

cin >> x; 

cout << "\nThe Number is:" << x << endl; 
// اظهار محتويات المتحول‎ 

cout <<"\nand The address in memory is:"<< 

&x << endl; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


اظهار عنوان المتحول// 
} 


E CAWindows\system32\cmd.exe 
Enter Number: 2H 
The Number is:2MH 


and The address in memory is: HH1IBFSDS 
Press any key to continue . . . ”“ 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


6 المؤشرات والتصريح عنها 
المؤتر عبارة عن متحول يحتوي على عنوان في الذاكرة إو أيس قيمة عادية) ء وهو يشير الى (ما مزه ۴) العتوان 
الذي يحتويه و بالتالي فهو يتير إلى متحول أخ ... 


بم التصريح عن المؤتر في البرنامج بتحديد تو ع المعطيات التي يقير اليها (أي هل يتير إلى قيمة من تو ع امز 
ئ8 -مaطء‏ ..) تم اضافة العامة (الرمز) نجمة * تم اسم المؤشر. 


Memory 


حمتحرل» * < نرع المعطيات التي يتير لها المؤتر» 


double *dptr; 


محاضرات في برمجة 1 )٤)++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


لا حظوا معي: 

المنحول مامز هو عبارة عن مؤشر من انوع الصحيح , أي عنران في الذاكرة بألف من حجرئبن ومحئوبات هائين 
الحجرئين سوف تسر على انها عاد صحبحة . 

لمتحول ار هو عبارة عن مؤشر من النوع الحقيفي , أي أن العتران المخزن في المتحول ينهم على أنه عنران 
بداية مساحة من الذاكرة بطول أربعة بابئات ومحثريات هذه الحجرات أعداد صحبحة . 

المتدول ٣ار‏ هو عبارة عن مؤشر من الئوع المضاعف , أي أن العنران المخزن في المتحول بفهم عى أنه عنران 
بداية مساحة من الذأكرة بطول ثمائية بايئات ومحئريات هذه الحجرات أعداد من النمط المضاعف , 


تا ان الرمز ج بابد عنران المتغير في الذاكرة؛ لإحظ هذا المثال ٠‏ 


inty = 5;‏ 
int “yPtr;‏ 
ر أخذٰ عنران ر // ;رچ = ۲ا۷۴ 
ان ائشاء المؤشر بم على مرحلئين: 
الإولى نعن يها عن المؤشر ٣ار‏ و الثابة سك اليه عنوان متحول في الذاكرة و للك يعني ان ٣٣ر‏ سوف 
يشيرإلى المنحرل رفي الذاكرةر بلي من الممكن النعامل س بشکل غير مباشر عن طریق yPir‏ ي بمعنی 
أذر أصبحت اللبمة داخل ر الخمسة هي تفسها محئوى اللبمة الئي يشر البها المؤشر ٠٣ر‏ . 
كل المنحرلات من نوع مشر لها س الحجم في الأأكرة و هر حجم العنوان الذي تحريه (فهي مجهزة لنخزين 
العارين) 


#include<iostream> 

using namespace std; 

int main () 

{ 

int x = 1, y = DD; 
cout<<endl<<&x<<endl1l<<Ey; 
int * ptr; 


ptr = &x; 
cout<<endl<<ptr ; 
ptr = &y; 


cout<<endl<<ptr<<endl ; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


Press any key to continue . . _ 


إن هذا البرنامج بوم بتعريف المتحولين لإ , × ويهبئهما بالقيمتين 5 , 1 ومن ثم يوم بطباعة عنارينهما, ومن دم يوم 
بتعريف متحول من نوع مؤشر إلى قبمة صحيحة وذاك من خلال الأمر: (× * ار). من المعلوم أنه لدى تعريف 


متحول ما فإنه لن تكون له أبة فبمة, وبالتالي يمكن أن يأخذ قبمة عشوائية, ولكن في المؤثرات فإن هذه الفبمة تمل 
عنوانا من الذاكرة. ولذا بتوجب قبل استخدام أي مؤشر أن نضع فيه عنوانا محذداً. 

وخلاصة الول : إن المؤشر يحمل عنوان متحول من نوع ما, وهذا العذوان يجب تحديده وإلا فإن المؤشر فد يشير 
إلى غبر المكان المقصود. 


7 غاي المؤشر 


عندما نعرف عن مشر فإننا نستخدم الصيغة (۹111* إا) حبث ان اسم المؤْشر هر ٣أ‏ 1۴ن ؛ و لكننا نستخدم 
الصيفه va‏ *داخل البرنامج (كنعير) س اڃجل الوصول إلى محتریاٽت المنحرل الذي يشير الله المؤشر tc vatPfr‏ 


ويسمى غابة المؤشر 


يستخدم اسم المؤشر مسبوق بالنجمة في) #include<iostream>‏ 
ارتا من اجل الوضل اع using namespace std;‏ 
سحتويات المتحول الذي يشير )( void main‏ 
{ 

int *varPtr; 
int var = 20 ; 
varPtr = &var; 


محاضرات في برمجة 1 (++0) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


cout << *varPtr; // 20 
cout << var<<endl ; // 20 


} 


E CA Windaws\system3Z2\cmd.exe 


2Z 
Press any key to continue . . _ 


و هكذا علينا الإنتباه إلى : 


٠‏ استخدام ٣ا‏ 1۴و* في جملة الأعلان ;إأ۴إوب* إو تعني اننا نعلن عن مؤشر اسمه ٥1ج‏ و 
يشير إلى قبمة من وع عدد صحيح . ا 
استخدام ٣1ج‏ في البر نامج كتعبير ;۲ا 1۴ة* >> رامع تعني اننا تتعامل مع محترى الفيمة 
الني يشير الها المؤشر ٣ا‏ ٣۲ه٠‏ . 


8 الوصول إلى المنحول المشار إلبه : 


يمكن الوصول إلى محتويات متحول لا نعرف اسمه ولكننا نعرف عنوانه كما في المثال التالي: 


#include<iostream> 
using namespace std; 
int main () 


{ 

int x = 1, y = 5; 
int * ptr; 

ptr = &x; 
cout<<endl<<*ptr; 
ptr = &y; 


cout<<endl<<*ptr<<endl ; 
return 0; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


0 + مھ *٭‎ ١ 
E] CN Windows\system32cmd.exe 


Press any key to continue . 


عند وضع عنوان متحول ما ضمن مزشر يجب أن بون المتحول والمؤشر من نفس النوع ولا يمن وضع عئوان 
متحول من نوع ا02[ ضمن مؤشر إلى الثر غ أا 
لكن تعريف المؤشر مؤشر إلى 1هن مثل ( ام * لهس ) يجعل من الممكن لهذا المؤشر أن ب 


| يات 


#include<iostream> 
using namespace std; 
int main () 


لاان عن مرلن صدبعين || 
o Fa LN‏ ا 8 1 1 
الإعلان عن مؤشر بشير إلى يمه من نوم علد ديح || 


{ 1 

الإعلان عن مرش الي بشبر إلى أيه من نوغ علد صحبح || ,5 = int valuel‏ 
جل المؤشر الإرل بشبر إلى المنحول ار value2 =15; |١‏ 

جعل المؤشر الثاني بشير إلى المندرل الثاني int* pl; |١‏ 

تخزین الا 10 في نول الي پیر لبه لمزشر int* p2; |١‏ 


مساراة ت لئم تا اي نشبر لبا لپا المإشر ات٣‏ 
جال پالمزشر اللي بش ای امول ل تی شیر الا اثر الا ld‏ 


pl = &valuel; 
P2 = &value2; 


تخزين اللبمة 20 في المتحرل الذي يشير اليه المرشر الإرل ١ا‏ ;10= *p1‏ 
x*p2 = *pl; :‏ 

p1 = p2; 

*p1 =20; 


cout << "valuel==" <<valuel<<" value2=='"<< 
value2<<endl; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


return 0; 


} 


E CA Windawsi\system3Z2\cmd.exe 


value1==1H valued2==28 
Press any key to continue _. 


ملاحظاث. 
يمكن للمؤشرات أن تأخذ عنوائاً جديداً بالمعامل سمج أو أن تأخذ عنوان أحد المتحولات الئي تنسجم مع ما تؤشر 
علبه (أي لا يجوز إسناد عنوان متحرل إو إلى موشر على 1وه[f)‏ والحجز من خلال المعامل عن يئم بالكل 
ا 2 
a‏ 

ڀا 


PointerVar=new datatype; 


حبث م و41 هي نمط قيمة المؤشر عندما صرحنا عئه وهئا يئم حجز مكان جديد في الذاكرة. 
| سن وسرل لے سکن الول الذي من نمط مؤشر إلا بعد أن تثم نهبئته أي بعد أن يحمل عنوانا معبنا). 
الحذف آي تحرير المنطفة الذاكرية المحجوزة لهذا المرشر بئم من خلال التابع ما [عل وفق الصبغة: 
delete PointerVar:‏ 


القيمة الخاصة N11‏ تعني أن المؤشر لا يؤشر على أي قيمة و هي مخئلفة عن المعامل ع)[عل فعند عملية 
التحرير هذا پعني ان امار ا چ کان في اکر آي آندخله لا پوجد خان اکري لحڊرة ‏ ما بینما عند 
إسناد القبمة 1ل هذا يعني أن له قبمة خاصة لا نمثل عنراناً فعا مئل الصفر) والوصول إلى القبمة المحئواة 
ضمنه سیولد خطاً. 

يجب الانتباه أن إسناد المؤشرات يودي إلى أن تحمل نفس العنوان و بالتالي أي تغبير في المحتوى يسري مفعوله على 
کا لفتخرلن أماكغير لبم فاخ مفعر ل ر1 رة ر نى العناوين منفصلة علماً أن إسناد موشرات مر ن فيم مخئلفة 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ, صلاح الحجري أعبدالقادر البعدانى 


غير مقبول حتى لو كانت أكبر أي مؤشر عى فيمة f04‏ لا يمكنه أن يحتوي على مؤشر على قبمة ٤رر‏ ببنما اليم 


الي شي سن مط ار floats‏ دش لئس القراعد التي تعلمناها 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


F۴F|LES الملفات‎ 


الملفات هي عبارة عن وسائط اتخزين البيانات بحيث يتم الكتابة عليها و تحفظ هذه البيانات 
بداخلها 

سنقوم بهذا الدرس بشرح كيفية التعامل مع الملفات من حيث الفراءة و الكتابة على أن نستعين 
ببعض مكتبات لغة © 


شرح بعض تعليماث لغة © 
أولا يجب أن نعلم أن المكتبة الداعمة لهذه الأوامر هي < 0.۸ألأي> 


الشرح 
لفثح ملف يجب علينا تحديد مسار هذا الملف و امثداده 


(مقدمة للبرمجة 
ريجب علبنا أبضا تحدبد مكان في الذاكرة لحجزه لهذا الملف.بالتعليمة * ۴|1٤‏ 
ویج عابنا الائئباد أن الکلمة ۴|1٤‏ بج أن نكب بأحرف كبيرة حصرا 
وعند فح هذا الملف يجب علبنا إخبار البرنامج بأننا هل ريد الثراءة من هذا الملف أم الكئابة 


ا الائبن معا , 
فلكتابة نستخدم :) f = fopen(‘c:l\student.txt", "Ww"‏ 
أما للفراءة فستخم ا 


وفي حال الراءة و الكثابة نستخدم "+" أو "+" 


مثال:1 
#include<iostream>‏ 
using namespace std;‏ 


محاضرات في برمجة 1 )٤)++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


vOid main ( ) 

{ 

FILE *f; 

f=fopen ("c:\\stdudent1. txt", "w") ; 
fprintf (f," welcome to C++"); 
fclose(f); 

} 


وإن النعليمه ٣إ۲م]‏ تكافئ النعلبمه 0ع في المكنبه 052| 
ومن أجل اغلاق هذا الملف استخدمنا هذا الكرد 


fclose(f); 

وإن هذه التعليمة تقوم بإغلاق هذا الملف وتنهي التعامل معه وعذم كتابة هذه التعليمة يمكن أن 
يؤدي في بعض الأحبان إلى تلف أو ضياع البياناك . 

* عند الطلب من البرنامج أمر فتح ملف فإن البرنامج إن لم يجد هذا املف فإن البرنامج 
ET‏ 

ملسو هذا الملف. ۰ | 

* في حال عدم كتابة مسار الملف المنشأً من قبل البرنامج إن البرنامج سينشئ هذا الملف في 

أ 2 * ۲ 3 أ ۲ 
المسار الأفتراضي للبرنامج ) المسار الموجود به البرنامج ا 


أ“ 
ف 


اكثب برنامج يفوم بإنشاء ملف نصي من أجل نخزين علامات طالب ضمن هذا الملف 


#include<iostream> 

using namespace std; 

vOid main ( ) 

{ 

FILE *f; 

int score; 

f=fopen ("c:\\stdudent1. txt", "w") ; 
cout<<"enter a test score (O0 terminate 
input)"; 

cin>>score; 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


while (score !=0)‏ 
{ 
fprintf (f, "Sd\n",score) ;‏ 
cout <<"enter anather score";‏ 
cin>>score;‏ 
} 
fclose(f);‏ 
} 
اكتب برنامج يقوم بقراة بيانات الموظفين ويتم 
تخزينها في الملف 1غخstduden‏ علما ان بيانات 
الموظفين تتظمن الرقم الاسم الراتب. 
#include<iostream>‏ 
using namespace std;‏ 
void main ( )‏ 
{ 
FILE *myfile;‏ 
الاسم بهذا الذاكرة في مكان حجز// 
struct employee‏ 
السجل كتابة// 
{ 
int empno;‏ 
السجل داخل الموظف رقم تعريف // 
char name [10];‏ 
0 []: السجل داخل الموظف اسم مصفوفة تعريف// 
float salary;‏ 
السجل داخل الموظف راتب تعريف // 
;} 
employee emp [100];‏ 
0 []:; للسجل متحول مصفوفة تعريف // 
int i1i,n;‏ 
myfile=fopen ("c:\\stdudent1. txt", "w") ;‏ 
cout<<"enter the number of employee<=100";‏ 
cin>>n;‏ 
for (i=0;i<n;i++)‏ 
إدخالها المراد السجلات عدد تحديد// 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


{ 
cout<<"enter the number of employee"<<i<<" 


Moo 
4 


cin>>emp [i] . empno ; 
cout<<"enter the name of employee"<<i<<" 


Moe 
4 


cin>>emp [i] .name; 

cout<<"enter the salary of employee"<<i<<" 
cin>>emp [i] .salary; 

fprintf (myfile,"Sd\tss\t%f\n" , emp [i] . empno , emp [ 
i] .name,emp [i] .salary) ; 

} 

fclose (myfile) ; 

الملف إغلاق أمر// 

} 

#include<iostream> 

نفس السابق ولكن اضافة شرط // 

using namespace std; 

void main ( ) 

{ 

FILE *myfile; 

الاسم بهذا الذاكرة في مكان حجز// 

struct employee 

السجل كتابة// 

{ 

int empno; 

السجل داخل الموظف رقم تعريف // 

char name [20]; 

0 ]; السجل داخل الموظف اسم مصفوفة تعريف// 
float salary;‏ 

السجل داخل الموظف راتب تعريف // 

}; 

employee emp [100]; 

0 []; للسجل متحول مصفوفة تعريف // 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


int i1i,n; 

myfile=fopen ("stdudent1l. txt", "w") ; 

if (myfile==NULL) 

{ 

cout<<"can not open file"; 

exit(-1); 

} 

cout<<"enter the number of employee<=100"; 
cin>>n; 

for (i=0;i<n;i++) 

إدخالها المراد السجلات عدد تحديد// 

{ 

cout<<"enter the number of employee"<<i<<" 


cin>>emp [i] . empno ; 
cout<<"enter the name of employee"<<i<<" 


MWe 
r 


cin>>emp [i] .name; 
cout<<"enter the salary of employee"<<i<<" 


Moe 
4 


cin>>emp [i] .salary; 


fprintf (myfile,"Sd\tss\t%f\n" , emp [i] . empno , emp [ 


1] .name,emp [i] .salary) ; 
} 

fclose (myfile) ; 

الملف إغلاق أمر // 

} 


محاضرات في برمجة 1 (++)) ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


مقدمة (مقدمة للبرمجة3) 
OBJECT ORIENTED PRORAMMING‏ 
برمجة هدفيه التوجه بلفة ++ 


الفئات والكائنات (٤ءءز0b‏ & sءھاC٣):‏ 
مفدمه: 
يعتبر مفهوم الفئة ووهآإع واحدا من أفضل ميزات لغة سي (C++ ) ٣٣‏ التي لم 
تكن موجودة في لغة ( ))C‏ الفئة هي مجموعة من البيانات والدوال 
)۴uncti008(‏ التي تعمل على هذه البيانات» أما الكائن ( ectز0b)‏ فھو تطبیق 
محجوز في الذاكرة يستخدم وفقا لتعريف الفئة النوع . 
في لغة سي ++ ( ++0)لا يوجد فرق عملي بين التركيبات ( ءعrا (stu)‏ 
والفئات ( وعويیهاء)ء» خاصة بعد قابلية التركيبات لإحتواء دJIg (Functions  )‏ 
ضمن متغيراتها كإضافة جديدة للغة سي ++ ( ++ )على لغة سي ( €)» ولذلك 
فبامکان کلا منهما الإستخدام تبادلیاء لکن معظم مبرمجي لغة سي ((C++ J+‏ 
يستخدمون التركيبات من أجل إحتواء البيانات فقط (كما كانت عليه في لغة سي ٤)»ء‏ 
ويستخدمون الفئات للتعامل مع كلا من البيانات والدوال. 
التصريح عj‏ أ (Declaration of Class)‏ 
التصريح عن الفئة يحدد أعضاءها من دوال وبيانات» كما يقوم بتحديد 
المدى(عمدء؟ إمMemb)‏ لكل عضو من أعضاء الفئة الشكل العام للتصريح عن 
الفئة كالتالي: 
class class_name‏ 
{ 
private:‏ 
DataMembers declaration;‏ 
FunctionMembers declaration;‏ 
public:‏ 
DataMembers declaration;‏ 
FunctionMembers declaration;‏ 
;} 
إن الكلمة المحجوزة (ءءه1ء) تخبر المترجم(إء ازم مه ) أن ما يليها هو إسم 
فئة ومابعده هو تصريحات أعضاء تلك الفئة» وكما هو الحال مع التركيب فإن 
التصريح عن الاعضاء يحاط بحاصرتين وينتهي بفاصلة منقوطة. 


محاضرات في برمجة 1 )٥++(‏ ( نظري + عملي ) إعداد: أ. صلاح الحجري أعبدالقادر البعداني 


أعضاء الفنة (كإعطدصرعم ووه1اء): هي المكونات ذات الانواع المعروفة التي 
ر يح عنها في جسم الفئةء وهي إما بيانات (Data)‏ او ڏJIg «(Functions)‏ 

بعض المؤلفين يسمون الدالة الخاصة بالفئة او الكائن بالطريقة ( ل0طاعص)» بينما 
ا هنا بتسمية البيانات التابعة لفئة بأعضاء البيانات( ءإمطمرعM‏ هه0) والتابعة 
لفئ بlلأعضاء .(Member functions) Jll‏ 

أما الكلمتين المحجوزيتين ( عأه۷اإم)ر(ءنااسم) فهما وسيلة البرمجة الهدفية 
في تغليف الكائن والفة ( «٥ناهاuومهءمع)‏ أو ما يسمى بإخفاء البيانات ( واهل 
عinلiط)»‏ وهما مصطلحان يقصد بهما عملية أمنية البيانات وجعلها حصرية في 
النطاق المطلوب» فالأعضاء (من بيانات ودوال )التي تأتي بعد الكلمة ( ماو۷|ام) 
تكون أعضاء حصرية للإستخدام على مستوى الفئة وأعضائها من بيانات ودوال 
أيظاء أما الكلمة المحجوزة ( عناطانم) فتعني ان الأعضاء التالية غير حصرية 
الاستخدام» آي ان مدی الإستخدام والتعامل (عsc0p)‏ مدى عام» سواء على مستوی 
الذالة الر تة ( ونو أي الات الأخر ى إن اد كخ اللقاتى هى الرقع الخاض 
المحلي (عاهر1إم) بالنسبة لمحتوى الفئة. 

والآن لنرى بناء جملة تحتوي على فئة في المثال الثالي؛ 


class rectangle 
{ private: 
int len,br; 
public: 
void getdata0O; 
void setdata(int I,int Db); 
void displaydata( ); 
void area_peri( ); 


} 


لقد أنشأنا الآن نوع بيانات جديد إسمه ( ٤اC1ANG€NRE))›‏ یتکون نوع 
البيانات الجديد هذا من ستة أعضاء» عضوي البيانات ( إط)و(هء1) وهما من النوع 
العددي الصحيح» وأربعة أعضاء كلها إجراءات» كتبت التصريحات الخاصة بها ولم 
يتم تسجيل التعريف الخاص بعمل كل واحدة. 

سنقوم فيما بعد بكتابة محتوى كل واحدة من الإجراءات/الدوال المصرح 
عنها في جسم الف( رلهط ءوه[ء)» من الملاحظ ان الدوال جميعها معرفة في خانة 
الأنواع العامة( «(public‏ بينما المتغيرات (البيانات) معرفة في جانب النوع ذڏي 
المدى الحصري على مستوی الفئة( «(private‏ و هذه هي العادة الغالبة على 
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مستخدمى البرمجة الهدفيةء إذ ان المطلوب فى الغالب هو كتابة أعضاء دوال تنفذ 
غار ارات فک شو ازا ` 

وهذا لا يعني ان هتات قواعد تتم کون البيانات الأعضاء في الفئة ذات مدى 
محلي»› والدوال الأعضاء ذات مدی عام» اد یمکن للمبرمج في أحيان أخرى 
التصريح عن أعضاء خاصة/محلية وبيانات عامة أو عن بيانات ودوال عامة حسب 
رغبة المبرمج. 

إنشاء مثال/متغير عن الْفنّةَ (معرهائم ssواc):‏ 

إن نوع البيانات ( ٤4٥1؟)‏ مثلاً يعرف طريقة معينة للتعامل مع البيانات التي 
من ذلك النوع» ولو عرفنا متغيرا و من ذلك النوع لاستخدمنا الجملة : 
Float y;‏ 

في هذه الجملة ندعو المتغير ر بأنه مثال للنوع هه[ يحجز موقعا في الذاكرة 
بذات مواصفات ذلك النوع (المسجلة مسبقا)» بنفس الطريقة نقوم بتعريف مثال 
(ععمهاءمة) للفئة التي نرغب بتعريف مثال عنهاء مثلاً نقوم بتعريف مثال عن الفئة 
السابقة (فئة نوع البيانات) المعرف أعلاه بالإسم ) «(rectangle‏ وذلك بنفس 
الطريقة: rectangle r1,r2;‏ 


إننا بهذه الجملة قد عرفنا (متغيرين ۲1 و ۲2) من النوع (ع[عمه)ءمء)» وكل 
ميز هى مثال عن الفة المعرفة أعلاه أي آنا تغرف كائن بقوم بتفس الذؤر 
المرسوم له في تعريف الفئة ( معاعمه)ءع)» وهي طريقة مشابهة للتصريح عن 
مر کا ودا ف المتر ات اة نة . .جي وگن الفار ى هتا ان رع 
العاات مرف عن طروق الستكم فة 

عندما نعرف متغير من نوع صحيح مثلاء فإنه يحجز في الذاكرة حيزا يسع 
2بايت من البيانات (يعتمد حجم نوع البيانات المحجوز على المترجم ونظام التشغيل 
المستخدم» ولنتذكر الدالة 0۴0عzو)ء‏ وهذا يعني بنفس الطريقة انه عند تعريف كائن 
)ءاه فإنه يقوم بحجز حيز من الذاكرة» في حالة الكائن ۲1 مثلا فإن الحيز من 
الذاكرة يساوي مجموع الانواع القياسية المعرفة في التصريح العام عن الفئةء وعند 
ريف اكان اركر 2 هدت حجر ساح مشاه اما لكان الفاق بن 
الطريقة. 

من المهم التأكيد على ان التصريح عن فئة وووه1ء لا يؤدي لحجز اي نطاق 
فعلي في الذاكرة» وأن ذلك يحدث فقط عند تعريف كائن( ءع زط٥‏ عمع«هtءم)‏ من 
تلك الفئة. 

:(Accessing class nembers)iiill ءlضعeÎ الوصول إلى‎ 

إذا كان عضو الفئة من النطاق المحلي عه مء فإننا لا نستطيع الوصول 
إليه على مستوى الدالة الرئيسة (0)«نهص؛ إن الاعضاء المحلية تكون قابلة الوصول 
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لديها متاحة فقط على مستوى تعريف الفئةء فلإسناد قيم أو إطلاق قيم لأعضاء محلية 
(بيانات كانت او دوال ) فإننا نستخدم الدوال الخاصة بالفئة نفسها. 

ولإستخدام دالة عضو في كائن نستخدم إسم الكائن ملحوقا بنقطة اهل ثم إسم 
ذلك الدالة ( ()0۸ناعصد؟.اءعزطاه) كما هو موضح في المتال التالي بخصوص 
الكائن ۲1: 

r1.setdata(10,20); r2.setdata(4,5); 

إن المتغيرين إط و ]1 يحجزان موقعين في الذاكرة كمتغيرين صحيحين مرة 

ضمن الكائن ۲1 ومرة ضمن الكائن ۲2 حسب الشكل التالي: 


تعريف (الأعضاء الدوال ) لا 

بالإمكان تعريف وكتابة محتوى العضو الدالة في الفئة إما ضمن الحاصرتين 
في الفئة نفسها أو خارج حاصرتي الفئة حسب ما سوف توضحه الأمثلة التاليةء لنعد 
لمثال المستطيل السابقء ولنعرف محتوى الدوال التي فيه ضمن حاصرتي الفئة 
ليكون شكل التصريح عن الفئة كالتالي : 


Class rectangle 
{ 
private: 
int len,br; 
public: 
void getdata0) 
{ 
cout<<endl<<""'enter length and breadth''; 
cin>>len>>br; 


} 
void setdata(int I,int b) 
{ 


len=J; 
br=b; 


} 
void displaydata() 
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{ 


cout<<endl<<""length='"<<len; 
cout<<endl<<"'"breadth='"<<br; 
} 

void area_peri) 

{ 

Int a,p; 

a=len*br; 

p=2*(len+br); 
cout<<endl<<"'area=''<<a; 
cout<<endl<<'""'perimeter=''<<p; 


ا 
j};‏ 
ولكتابة الدوال خارج حاصرتي الفئة فاننا نستخدم المؤثر :: هذا المؤثر يعني 
أن الدالة على يساره هو عضو في الفئة المذكورة قبله على الصورة: 
Return-type calss_name::function_name(argument lis)‏ 


{ 


....function body..... 


حيث أن عمرا-١إں)ءR‏ تعني نوع البيانات الذي يعيده الدالة ( dزم‏ أو ہز 
أو هطع أو غيره من ...) 

عمصهم_ءء[هء إسم الفئة التي ينتمي إليها الدالة 

:: المؤثر المذكور 

function_na me‏ إسم الدالة المقصود كتابة محتواه. 

ئ argument‏ قائمة المتغيرات المدخلة ضمن الدالة (إن وجدت). 
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تمرین : 

أعد كتابة المثال السابق بطريقة تعريف الدوال خارج حاصرتي الفئة» مع 
أخذ الملاحظة رقم 1 أدناه بالاعتبار. 

ملاحظات : 

1. من ال كتابة الدالة خارج حاصرتی ي التصريح عن الفئة class‏ 
arati0nاecل»‏ يجب كتابة تصريحات عن الدوال الأعضاء ضمن إطار التصريح 
عن الفئة كما هو موضح في أو مثال و 
‘ninê‏ أما الدوال المعرفة خارج إطار حاصرتي الفئة قلست من 
مصiامء‏ ولكي يتم تعريفها كدوال من تلك الصفة»ء يتم كتابة الكلمة المحجوزة 
مص1م قبل تعريف الدالة فيصبح الشكل العام أعلاه كالتالي: 

Inline Return-type calss_name::function_name(argument 
lis) {} 

ما هي الدوال من inline‏ ؟ 
الفئات الكبيرة إذ الاك عادة كتابة تصريحات eT‏ 
)headf1e)*.1((‏ ويتم كتابة محتوى الدوال (التعريف) a‏ 
(ممء.*) وذلك عند تأسيس المكتبات كع 1إهإط:1 المحتوية على عدد كبير من 
الفئات. 

4. الفئة المحلية (sئھاء‏ 21ء10) هي الفئة التي يتم التصريح عنها داخل الدالة 
الرئيس (١«٥0ناعصنا؟‏ «هنص)» ولا يصح في حالة التصريح عن فئة محلية أن يتم 
التصريح عن الدوال الاعضاء فقط من أجل التعريف خارج جسم الفئة. 


الكائنات والدوال 

كما درسنا في الدوال ك١‏ ٥ناعصں؟‏ فإننا نعلم انها مجموعة أوامر يكتبها 
المستخدم» وتقبل مجموعة من المتغيرات» وتقوم بتنفيذ مجموعة الأوامر تلك» ثم 
تعيد(٥إا]ع])‏ مجموعة من المتغيرات الناتجة. 

نحن نعلم ان بعض الدوال لا تقبل متغيرات» كما آنه بالإمكان أن لا تعيد 
بعض الدوال اي متغير» إن تعامل الكائنات مع هذه الدوال يعتمد على مدى 
العضو (إعbا )scope of the nem‏ المستخدم. 

أما بخصوص الدوال التي تقبل أو تعيد متغيرات» فهي تتعامل مع الكائنات 
.. ولکن كيف؟ 
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تمرير كائن كمتغير في دالة: 
كما هو الحال مع المتغيرات في الانواع القياسية المعروفةء فإن من الممكن 
تمرير كائن إلى دالة إما بالقيمة ( عuاجv‏ رط) أو بالمرجع ( eع«عإمfم]‏ yط)»‏ في 
المثال التالي يقوم البرنامج المكتوب بتعريف فئة ثم القيام بإستخدام دوال المكتبة 
(18.۲٣اء)‏ في دمج قيم كائنين من نوع تلك الفئةء (أي قيم عضوي بيانات في 
کائنین بالطبع): 
#include <iostream.h>‏ 
#include <string.h>‏ 


Class str 
{ 
private: 
char s[50]; 
public: 
void set (char *ssS) 
{ 
StrCpy(S,SS); 
} 
void print() 
cout<<s<<endl; 
} 
void concat (str S2) 
{ 
strcat(s,S2.S); 
} 
} 
void main() 
{ 


str s1,S2; 
s1.set(''hand in'""); 
sS2.set(''hand'""); 
s1.concat(s2); 
s1.print(Û; 
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تحتوي الفئة ء)ء على متغير محلي هو عبارة عن سلسلة نصية (مصفوفة 
محارف ءrماcھarطc‏ fه array‏ )» وعلى ثلاثة دوال تقوم الدالة (ء؛ بقبول 
سلسلة نصية وخزنها (بنسخها) في المتغير المحلي» كما تقوم الدالة 1010م بطباعة 
محتوى السلاسلة النصية > في حین تقوم الدالة conc0‏ بدمج محتوى تلك الساسلة 
النصية لهذه الفئة(الكائن بالطبع) مع سلسلة نصية مشابهة لكائن من نفس نوع 
الفئة(اي انه يشترط ان يحتوي على سلسلة بنفس الاسم والنوع). 
في الدالة الرئيس ,هص يتم إسناد سلسلة نصية للكائن 1ء عبر الدالة (t)0عوء‏ 
> ونفس العملية بالنسبة للكائن 2ء ثم يتم في السطر الرابع إستخدام الدالة العضو في 
الكائن 1ء لتنفيذ عملية دمج السلسلتين في الكائنين» ومن تم في السطر الخامس 
ظا عة مخرئ الساسلة فى الكان وبع الكفج 
نتيجة البرنامج السابق هي (لمaط .(hand in‏ 
ولكن ما الذي سينتج؟ .. إذا تم إستبدال الكائن 2 بالكائن 1ء في السطرين 
الرابع والخامس كالتالي: 
s2.concat(s1);‏ 
S2.printÛ;‏ 
ملاحظة : لا توجد علاقة بين الكائن 2ء المعرف في أول سطر بالدالة الرئيس 
in0عص»‏ والكائن بنفس الاسم الممرر في تعريف الدال «void concat (sr S2)‏ 
حتى لو تم إستخدام نفس المحارف للتسميةء »> إل أن الكائن في تصريح تلك الدالة هو 
مجرد كائن وهمي يستخدم (كما هو الحال في الدوال ) لتوضيح الإجراءات المستخدمة 
في حال تم تمرير كائن من النوع ١ءء‏ وذلك دون ان يتم إعتباره كائنا فعلياء بينما 
الكائن 2 المستخدم في الدالة الرئيس هو كائن حقيقي من النوع ٣أء.‏ 


تمرير مصفوفة كائنات كمتغيرات في دالة: 
بالتأكيد كما في التركيب نستطيع إنشاء مصفوفة كائنات» مستخدمین 
نفس طريفة بناء الجملة في التصريح عن مصفو فة أعداد صحيحية أو 
حقيقية(ءد | إ0 كإعععtم1)»‏ سوف يقوم البرنامج التالي بتعريف دالة 
عادية تقبل مصفوفة كائنات ممره إليه: 
class sample‏ 
{ 
private:‏ 
int i;‏ 
public:‏ 
void set(int ii)‏ 
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{ 


i=ii; 
} 
void print() 


cout<<endl]<<i<<endl; 
} 
J}; 
void show(sample *p)//non-memeber function.. 
{ 
for (int j=0;j<5;j++) 
plj].printO; 
} 
void main) 
{ 
sample s[5]; 
int x; 


for(int j=0;j<5;j++) 
{ 
cin>>x; 
s[j].set(x); 
} 


show(s); 
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المراجع: 


مواقع متنوعة عربية وانجليزية وكذلك ملفات اكر وبك متنوعة . 

للمؤلف مجلاد مشاري ++° موسوعة البرمجة بلغة « 

اصول البرمجة بلغة السي بلاس بلاس . 

= C++ How to Program, Fifth Edition 

للمؤلف محمد هنداوي ٥C++‏ خطوة خطوة مع « 

للمؤلف محمد ناشد ++0المؤشرات في . 

= Introduction To Object Oriented Programming & 
C++ 

= ەفلؤمل¥Yashavant{‎ Kan e)kھ۲ من منشورات‎ BBB 
PUBLICATION 
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#includeciostream //4 اكتب برنامج لابجاد قيمة‎ ٣۸*۸3*24 ل‎ 
using namespace std; | 
E void mainh () 
{ 
int X,Y; 
cout<¢"insert secon"; 
cin?Dk; 
couttt4*x*x+3*x-4ctendl; 
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There are no usable controls 
in this group, Drag an item 
onto this text to add it to the 
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90 prog - Microsoft Visual Studio 
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= اد ا 
EE TIE E N TT E SEE Run Code Analysis on Selection‏ 
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(Global Scope) v 
There are no usable controls #includeciostream> //4 4-×*3+×*×*اكتب برنامج لايجاد قيمة‎ 2 3 Hender Files 
in this group, Drag an item using namespace std; ك‎ 
onto this text to add it to the E void mainh() N Resource Files 
toolbox, { 
int E,Y: 
coutt<"insert secon"; 
cin>>k; 
cout<{4*x*x+3*x-44¢endl; 
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